/* ============================================================
   StreamVault — main.css
   All styles extracted from the StreamVault HTML demo.
   Design tokens live in :root — change them here to restyle
   the entire site.
   ============================================================ */

/* ── Reset & Base ─────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:  #0c0c0e;
  --bg1: #111114;
  --bg2: #17171c;
  --bg3: #1e1e24;
  --bg4: #25252d;
  --line:  rgba(255,255,255,0.05);
  --line2: rgba(255,255,255,0.09);
  --line3: rgba(255,255,255,0.16);
  --t1: #f4f3ef;
  --t2: #a09fa8;
  --t3: #7a7985;
  --t4: #565660;
  --red:  #e8000d;
  --red2: #ff1a26;
  --f: 'Plus Jakarta Sans', sans-serif;
  --r4:4px;--r8:8px;--r12:12px;--r16:16px;--r20:20px;
  --ease: cubic-bezier(.25,.46,.45,.94);
}

html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--t1);font-family:var(--f);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button{font-family:var(--f);cursor:pointer;border:none;outline:none;background:none}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:4px}

/* ── Age Gate ─────────────────────────────────────────────── */
#sv-gate{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.92);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(6px)}
#sv-gate.sv-hidden{display:none}
.gate-inner{width:100%;max-width:380px;margin:16px;padding:40px 36px;background:var(--bg2);border:1px solid var(--line2);border-radius:var(--r20);text-align:center}
.gate-badge{display:inline-block;background:var(--red);color:#fff;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:4px 10px;border-radius:var(--r4);margin-bottom:20px}
.gate-inner h2{font-size:22px;font-weight:800;letter-spacing:-.4px;margin-bottom:10px}
.gate-inner p{font-size:13px;color:var(--t2);line-height:1.7;margin-bottom:28px}
.gate-actions{display:flex;gap:10px}
.gate-yes{flex:1;background:var(--red);color:#fff;font-size:14px;font-weight:700;padding:12px;border-radius:var(--r8);transition:background .15s}
.gate-yes:hover{background:var(--red2)}
.gate-no{flex:1;background:var(--bg4);color:var(--t2);font-size:14px;font-weight:500;padding:12px;border-radius:var(--r8);transition:background .15s}
.gate-no:hover{background:var(--bg3)}
.gate-note{margin-top:16px;font-size:11px;color:var(--t3)}

/* ── Header ───────────────────────────────────────────────── */
#sv-header{position:sticky;top:0;z-index:200;height:56px;background:rgba(12,12,14,.9);backdrop-filter:blur(20px);border-bottom:1px solid var(--line);display:flex;align-items:center;padding:0 24px;gap:20px}
.sv-logo{font-size:17px;font-weight:800;letter-spacing:-.5px;color:var(--t1);display:flex;align-items:center;gap:7px;flex-shrink:0;text-decoration:none}
.sv-logo-mark{width:22px;height:22px;background:var(--red);border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff}
.sv-hnav{display:flex;align-items:center;gap:2px;flex:1;list-style:none}
.sv-hnav a{font-size:13px;font-weight:500;color:var(--t2);padding:6px 12px;border-radius:var(--r8);transition:all .15s;white-space:nowrap}
.sv-hnav a:hover,.sv-hnav a.current{color:var(--t1);background:var(--bg3)}
.sv-search-trigger{position:relative;flex:1;max-width:220px}
.sv-search-trigger input{width:100%;height:34px;background:var(--bg3);border:1px solid var(--line2);border-radius:var(--r8);color:var(--t2);font-family:var(--f);font-size:13px;padding:0 12px 0 34px;cursor:pointer;outline:none}
.sv-search-trigger input::placeholder{color:var(--t3)}
.sv-search-trigger svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);pointer-events:none;opacity:.4}
.sv-hbtn{height:34px;padding:0 14px;background:var(--bg3);border:1px solid var(--line2);border-radius:var(--r8);font-size:13px;font-weight:500;color:var(--t2);display:flex;align-items:center;gap:6px;transition:all .15s;white-space:nowrap;flex-shrink:0}
.sv-hbtn:hover{color:var(--t1);background:var(--bg4)}

/* ── Search Overlay ───────────────────────────────────────── */
#sv-search-overlay{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.82);backdrop-filter:blur(14px);display:none;align-items:flex-start;justify-content:center;padding-top:80px}
#sv-search-overlay.open{display:flex}
.so-box{width:100%;max-width:580px;margin:0 16px}
.so-input-wrap{position:relative;margin-bottom:10px}
.so-input-wrap input{width:100%;height:50px;background:var(--bg3);border:1px solid var(--line3);border-radius:var(--r12);color:var(--t1);font-family:var(--f);font-size:16px;padding:0 48px 0 48px;outline:none}
.so-input-wrap input::placeholder{color:var(--t3)}
.so-search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);opacity:.5;pointer-events:none}
.so-close{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--t3);font-size:20px;line-height:1;padding:4px;transition:color .15s}
.so-close:hover{color:var(--t1)}
#so-results{background:var(--bg2);border:1px solid var(--line2);border-radius:var(--r12);max-height:calc(100vh - 220px);overflow-y:auto}
.so-hint{padding:24px;text-align:center;font-size:13px;color:var(--t3)}
.so-section-label{padding:10px 16px 6px;font-size:11px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--line)}
.so-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:background .12s;border-bottom:1px solid var(--line)}
.so-item:last-child{border-bottom:none}
.so-item:hover{background:var(--bg3)}
.so-item-thumb{width:56px;height:32px;border-radius:var(--r4);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:16px;overflow:hidden;background:var(--bg3);background-size:cover;background-position:center}
.so-item-icon{width:36px;height:36px;border-radius:var(--r8);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:18px;background:var(--bg3)}
.so-item-title{font-size:13px;font-weight:600;color:var(--t1)}
.so-item-meta{font-size:11px;color:var(--t3);margin-top:1px}
.so-no-results{padding:32px 16px;text-align:center;color:var(--t3);font-size:13px}

/* ── Mobile Bottom Nav ────────────────────────────────────── */
#sv-mob-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:300;background:var(--bg1);border-top:1px solid var(--line2);height:56px}
.mob-nav-inner{display:flex;flex-direction:row;height:100%}
.mob-nav-btn{flex:1;display:flex;flex-direction:column!important;align-items:center;justify-content:center;gap:3px;color:var(--t3);transition:color .15s;padding:6px 4px;text-decoration:none;background:none;border:none;cursor:pointer;min-width:0;overflow:hidden}
.mob-nav-btn.current{color:var(--red)}
.mob-nav-btn svg{display:block;flex-shrink:0;width:20px;height:20px;margin:0 auto}
.mob-nav-btn span{display:block;font-size:9px;font-weight:600;line-height:1.2;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}

/* ── Layout ───────────────────────────────────────────────── */
.sv-wrap{max-width:1240px;margin:0 auto;padding:0 24px}
.sv-section{padding:32px 0}
.sv-sh{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.sv-sh-title{font-size:16px;font-weight:700;letter-spacing:-.2px}
.sv-sh-link{font-size:12px;font-weight:600;color:var(--t3);display:flex;align-items:center;gap:3px;transition:color .15s;text-decoration:none}
.sv-sh-link:hover{color:var(--t2)}
.sv-bc{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--t3);padding:16px 0 0;flex-wrap:wrap}
.sv-bc a{transition:color .15s}.sv-bc a:hover{color:var(--t2)}
.sv-bc-sep{opacity:.3}
.sv-bc-cur{color:var(--t2)}

/* ── OTT Pills ────────────────────────────────────────────── */
.sv-ott-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;margin-bottom:24px}
.sv-ott-row::-webkit-scrollbar{display:none}
.sv-ott-pill{flex-shrink:0;height:32px;padding:0 14px;border-radius:100px;background:var(--bg3);border:1px solid var(--line2);font-size:12px;font-weight:600;color:var(--t2);cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px;white-space:nowrap;text-decoration:none}
.sv-ott-pill span{font-size:10px;font-weight:500;color:var(--t3)}
.sv-ott-pill:hover{background:var(--bg4);color:var(--t1);border-color:var(--line3)}
.sv-ott-pill.current{background:var(--red);border-color:transparent;color:#fff}
.sv-ott-pill.current span{color:#ffb3ac}

/* ── Episode Cards ────────────────────────────────────────── */
.sv-grid{display:grid;gap:20px;grid-template-columns:repeat(3,1fr)}
.sv-card{border-radius:var(--r12);overflow:hidden;background:var(--bg2);cursor:pointer;transition:transform .2s var(--ease),box-shadow .2s var(--ease);display:block;text-decoration:none}
.sv-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,.6)}
.sv-card:hover .sv-card-overlay{opacity:1}
.sv-card:hover .sv-card-thumb-img{transform:scale(1.06)}
.sv-card-thumb{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--bg3);width:100%}
.sv-card-thumb-img{position:absolute;inset:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px;transition:transform .35s var(--ease)}
.sv-card-thumb-img.has-thumb{object-fit:cover;display:block}
.sv-card-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.75) 100%);opacity:0;transition:opacity .25s;display:flex;align-items:center;justify-content:center}
.sv-card-play{width:48px;height:48px;background:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .2s,background .15s;box-shadow:0 4px 16px rgba(0,0,0,.5)}
.sv-card-play svg{fill:#fff;margin-left:3px}
.sv-card-plat{position:absolute;top:8px;left:8px;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08);border-radius:var(--r4);padding:3px 10px;font-size:11px;font-weight:700;color:var(--t1);letter-spacing:.03em}
.sv-card-new{position:absolute;top:8px;left:8px;background:var(--red);border-radius:var(--r4);padding:2px 7px;font-size:9px;font-weight:800;color:#fff;letter-spacing:.05em;text-transform:uppercase}
.sv-card-dur{position:absolute;top:8px;left:8px;background:rgba(0,0,0,.75);border-radius:var(--r4);padding:3px 10px;font-size:11px;color:var(--t2)}
.sv-card-fav{position:absolute;top:8px;right:8px;width:26px;height:26px;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;opacity:0;transition:opacity .15s;border:1px solid rgba(255,255,255,.08);color:var(--t2);cursor:pointer}
.sv-card:hover .sv-card-fav{opacity:1}
.sv-card-fav.on{opacity:1;color:var(--red2);background:rgba(229,72,58,.22)}
.sv-card-body{padding:14px 16px 16px}
.sv-card-title{font-size:15px;font-weight:600;color:var(--t1);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:5px}
.sv-card-meta{font-size:12px;color:var(--t3);display:flex;align-items:center;gap:5px}
.sv-dot{width:2px;height:2px;border-radius:50%;background:var(--t4);flex-shrink:0}

/* ── Portrait Cards ───────────────────────────────────────── */
.sv-pgrid{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}


/* ── Platform Cards ───────────────────────────────────────── */
.sv-plat-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}
.sv-plat-card{position:relative;background:var(--bg2);border:1px solid var(--line);border-radius:var(--r12);padding:20px 16px;cursor:pointer;transition:all .2s var(--ease);text-align:center;text-decoration:none;display:block}
.sv-plat-card:hover{background:var(--bg3);border-color:var(--line2);transform:translateY(-2px)}
.sv-plat-card-icon{font-size:32px;margin-bottom:10px}
.sv-plat-card-name{font-size:14px;font-weight:700;margin-bottom:3px;color:var(--t1)}
.sv-plat-card-count{font-size:11px;color:var(--t3)}

/* ── Horizontal Scroll ────────────────────────────────────── */
.sv-hscroll{display:flex;gap:14px;overflow-x:auto;padding-bottom:6px;scrollbar-width:none}
.sv-hscroll::-webkit-scrollbar{display:none}
.sv-hscroll 
.sv-hscroll .sv-card{flex-shrink:0;width:210px}

/* ── Episode Player ───────────────────────────────────────── */
.sv-ep-layout{display:grid;grid-template-columns:1fr 300px;gap:28px;align-items:start;padding-top:20px}
.sv-ep-player{width:100%;aspect-ratio:16/9;background:var(--bg2);border-radius:var(--r16);overflow:hidden;border:1px solid var(--line);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;position:relative;transition:border-color .15s}
.sv-ep-player:hover{border-color:var(--line2)}
.sv-ep-player iframe,.sv-ep-player video{position:absolute;inset:0;width:100%;height:100%;border:none}
.sv-ep-player-bg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:100px;opacity:.06;pointer-events:none}
.sv-ep-player-poster{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.3}
.sv-ep-play-ring{width:64px;height:64px;border-radius:50%;background:var(--red);display:flex;align-items:center;justify-content:center;transition:transform .2s,background .15s;z-index:1;flex-shrink:0}
.sv-ep-player:hover .sv-ep-play-ring{transform:scale(1.08);background:var(--red2)}
.sv-ep-play-ring svg{fill:#fff;margin-left:3px}
.sv-ep-player-label{font-size:13px;color:var(--t2);z-index:1}

/* ── Episode Info ─────────────────────────────────────────── */
.sv-ep-info{margin-top:18px}
.sv-ep-tags{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.sv-ep-plat-tag{background:var(--red);color:#fff;font-size:11px;font-weight:700;padding:3px 9px;border-radius:var(--r4);text-decoration:none}
.sv-ep-dur-tag{background:var(--bg3);color:var(--t2);font-size:11px;font-weight:500;padding:3px 9px;border-radius:var(--r4);border:1px solid var(--line2)}
.sv-ep-new-tag{background:rgba(229,72,58,.12);border:1px solid rgba(229,72,58,.3);color:var(--red2);font-size:11px;font-weight:600;padding:3px 9px;border-radius:var(--r4)}
.sv-ep-title{font-size:22px;font-weight:800;letter-spacing:-.4px;line-height:1.3;margin-bottom:8px}
.sv-ep-meta{font-size:12px;color:var(--t3);display:flex;align-items:center;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.sv-ep-desc{font-size:13px;color:var(--t2);line-height:1.8;margin-bottom:20px}
.sv-ep-actions{display:flex;gap:10px;flex-wrap:wrap}
.sv-btn-watch{background:var(--red);color:#fff;font-size:14px;font-weight:700;padding:10px 22px;border-radius:var(--r8);transition:background .15s;display:inline-flex;align-items:center;gap:7px;text-decoration:none}
.sv-btn-watch:hover{background:var(--red2)}
.sv-btn-ghost{background:var(--bg3);color:var(--t1);font-size:13px;font-weight:500;padding:10px 16px;border-radius:var(--r8);border:1px solid var(--line2);transition:all .15s;display:inline-flex;align-items:center;gap:6px;text-decoration:none}
.sv-btn-ghost:hover{background:var(--bg4);border-color:var(--line3)}
.sv-btn-ghost.on{background:rgba(229,72,58,.12);border-color:rgba(229,72,58,.35);color:var(--red2)}

/* ── Series Strip ─────────────────────────────────────────── */
/* ── Series block on episode page ── */
.sv-ser-block{margin-top:28px;background:var(--bg2);border:1px solid var(--line2);border-radius:var(--r16);overflow:hidden}
.sv-ser-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line)}
.sv-ser-header-left{display:flex;align-items:center;gap:10px}
.sv-ser-header-title{font-size:15px;font-weight:700;color:var(--t1)}
.sv-ser-header-count{font-size:11px;color:var(--t3);background:var(--bg3);border:1px solid var(--line2);border-radius:20px;padding:2px 9px;font-weight:600}
.sv-ser-header-link{font-size:12px;font-weight:600;color:var(--red2);text-decoration:none;transition:color .15s}
.sv-ser-header-link:hover{color:var(--red)}
.sv-ser-ep-list{display:flex;flex-direction:column}
.sv-ser-ep-item{display:flex;align-items:center;gap:12px;padding:11px 20px;border-bottom:1px solid var(--line);cursor:pointer;transition:background .15s;text-decoration:none}
.sv-ser-ep-item:last-child{border-bottom:none}
.sv-ser-ep-item:hover{background:var(--bg3)}
.sv-ser-ep-item.current{background:var(--bg3);cursor:default}
.sv-ser-ep-thumb{
  flex-shrink:0;
  width:120px;
  height:68px;
  border-radius:6px;
  overflow:hidden;
  background:var(--bg3);
  display:flex;
  align-items:center;
  justify-content:center;
}
.sv-ser-ep-thumb img {
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}
.sv-ser-ep-num{font-size:12px;font-weight:700;color:var(--t3);min-width:22px;text-align:center;flex-shrink:0}
.sv-ser-ep-item.current .sv-ser-ep-num{color:var(--red)}
.sv-ser-ep-name{font-size:13px;font-weight:500;color:var(--t1);flex:1;line-height:1.4}
.sv-ser-ep-dur{font-size:11px;color:var(--t3);flex-shrink:0}
.sv-ser-ep-playing{display:flex;align-items:center;gap:5px;flex-shrink:0}
.sv-ser-ep-playing span:last-child{font-size:10px;color:var(--red2);font-weight:700}
.sv-ser-ep-dot{width:6px;height:6px;border-radius:50%;background:var(--red);display:inline-block;flex-shrink:0}

/* ── Sidebar ──────────────────────────────────────────────── */
.sv-ep-sidebar{display:flex;flex-direction:column;gap:16px}
.sv-sb{background:var(--bg2);border:1px solid var(--line);border-radius:var(--r12);padding:16px}
.sv-sb-head{font-size:11px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:12px}
.sv-rel-list{display:flex;flex-direction:column;gap:8px}
.sv-rel-item{display:flex;align-items:flex-start;gap:10px;cursor:pointer;border-radius:var(--r8);padding:4px;transition:background .12s;text-decoration:none}
.sv-rel-item:hover{background:var(--bg3)}
.sv-rel-thumb{
  flex-shrink:0;
  width:80px;
  height:45px;
  border-radius:4px;
  overflow:hidden;
  background:var(--bg3);
  display:flex;
  align-items:center;
  justify-content:center;
}
.sv-rel-thumb img {
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}
.sv-rel-title{font-size:12px;font-weight:600;color:var(--t1);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sv-rel-meta{font-size:10px;color:var(--t3);margin-top:3px}

/* ── Profile Hero ─────────────────────────────────────────── */
.sv-profile-hero{background:var(--bg2);border:1px solid var(--line);border-radius:var(--r16);padding:28px;margin-bottom:28px;display:flex;align-items:flex-start;gap:24px}
.sv-profile-av{width:80px;height:80px;border-radius:50%;background:var(--bg3);border:2px solid var(--line2);display:flex;align-items:center;justify-content:center;font-size:34px;flex-shrink:0;overflow:hidden}
.sv-profile-name{font-size:24px;font-weight:800;letter-spacing:-.4px;margin-bottom:6px}
.sv-profile-bio{font-size:13px;color:var(--t2);line-height:1.7;max-width:560px;margin-bottom:14px}
.sv-profile-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.sv-profile-tag{background:var(--bg3);border:1px solid var(--line2);border-radius:var(--r4);padding:3px 9px;font-size:11px;font-weight:600;color:var(--t2);text-decoration:none;transition:border-color .15s}
.sv-profile-tag:hover{border-color:var(--line3);color:var(--t1)}
.sv-profile-stats{display:flex;gap:24px}
.sv-pstat-n{font-size:20px;font-weight:800;color:var(--t1)}
.sv-pstat-l{font-size:11px;color:var(--t3);margin-top:1px}

/* Platform hero */
.sv-plat-hero{background:var(--bg2);border:1px solid var(--line);border-radius:var(--r16);padding:24px 28px;margin-bottom:28px;display:flex;align-items:center;gap:20px}
.sv-plat-hero-icon{width:64px;height:64px;background:var(--bg3);border-radius:var(--r12);display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0;border:1px solid var(--line2)}
.sv-plat-hero-name{font-size:26px;font-weight:800;letter-spacing:-.4px;margin-bottom:6px}
.sv-plat-hero-desc{font-size:13px;color:var(--t2);line-height:1.7;max-width:500px;margin-bottom:12px}
.sv-plat-hero-info{flex:1;min-width:0}

/* ── Popular List ─────────────────────────────────────────── */
.sv-pop-list{display:flex;flex-direction:column;gap:4px}
.sv-pop-item{display:flex;align-items:center;gap:14px;padding:10px 12px;border-radius:var(--r8);cursor:pointer;transition:background .15s;text-decoration:none}
.sv-pop-item:hover{background:var(--bg3)}
.sv-pop-num{font-size:20px;font-weight:800;color:var(--t4);min-width:28px;text-align:center;line-height:1}
.sv-pop-num.top{color:var(--red)}
.sv-pop-thumb{width:72px;height:40px;border-radius:var(--r4);background:var(--bg3);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:18px;overflow:hidden;background-size:cover;background-position:center}
.sv-pop-title{font-size:13px;font-weight:600;color:var(--t1);line-height:1.3;margin-bottom:2px}
.sv-pop-meta{font-size:11px;color:var(--t3)}
.sv-pop-views{margin-left:auto;font-size:11px;color:var(--t3);flex-shrink:0}

/* ── Pagination ───────────────────────────────────────────── */
/* ── Pagination ─────────────────────────────────────────────
   paginate_links(type='plain') outputs bare <a> and <span> tags.
   We wrap them in .sv-pages (display:flex) for horizontal layout. */
.sv-pages{
  display:flex;
  flex-direction:row;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  gap:6px;
  margin-top:32px;
  padding:0;
  list-style:none;
}
/* Every link and span inside gets pill styling */
.sv-pages a.page-numbers,
.sv-pages span.page-numbers,
.sv-pg {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:34px;
  height:34px;
  padding:0 8px;
  border-radius:var(--r8);
  background:var(--bg3);
  border:1px solid var(--line);
  font-size:13px;
  font-weight:500;
  color:var(--t2);
  cursor:pointer;
  transition:all .15s;
  text-decoration:none;
  line-height:1;
}
.sv-pages a.page-numbers:hover,
.sv-pg:hover {
  background:var(--red);
  border-color:transparent;
  color:#fff;
}
.sv-pages span.page-numbers.current,
.sv-pg.on {
  background:var(--red);
  border-color:transparent;
  color:#fff;
  cursor:default;
}
.sv-pages span.page-numbers.dots {
  background:transparent;
  border-color:transparent;
  color:var(--t3);
  cursor:default;
  min-width:20px;
}

/* ── Empty States ─────────────────────────────────────────── */
.sv-empty{text-align:center;padding:80px 20px}
.sv-empty-icon{font-size:48px;margin-bottom:14px}
.sv-empty-title{font-size:18px;font-weight:700;letter-spacing:-.3px;margin-bottom:6px}
.sv-empty-sub{font-size:13px;color:var(--t3);margin-bottom:22px}

/* ── Toast ────────────────────────────────────────────────── */
.sv-toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--bg4);border:1px solid var(--line2);border-radius:var(--r8);padding:10px 18px;font-size:13px;color:var(--t1);z-index:9000;animation:svToastIn .25s ease;box-shadow:0 8px 24px rgba(0,0,0,.5);pointer-events:none;white-space:nowrap}
@keyframes svToastIn{from{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%,0)}}

/* ── 404 ──────────────────────────────────────────────────── */
.sv-404{text-align:center;padding:100px 20px}
.sv-404-code{font-size:80px;font-weight:800;color:var(--bg3);line-height:1;margin-bottom:16px}
.sv-404-title{font-size:22px;font-weight:700;margin-bottom:8px}
.sv-404-sub{font-size:14px;color:var(--t3);margin-bottom:24px}

/* ── Footer ───────────────────────────────────────────────── */
#sv-footer{background:var(--bg1);border-top:1px solid var(--line);padding:40px 0 24px}
.sv-foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:32px}
.sv-foot-desc{font-size:12px;color:var(--t3);line-height:1.8;max-width:240px;margin-top:10px}
.sv-foot-col-title{font-size:11px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:12px}
.sv-foot-links{display:flex;flex-direction:column;gap:9px}
.sv-foot-links a{font-size:13px;color:var(--t3);transition:color .15s}
.sv-foot-links a:hover{color:var(--t2)}
.sv-foot-bottom{border-top:1px solid var(--line);padding-top:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.sv-foot-legal{font-size:11px;color:var(--t4)}
.sv-foot-legal-links{display:flex;gap:16px}
.sv-foot-legal-links a{font-size:11px;color:var(--t4);transition:color .15s}
.sv-foot-legal-links a:hover{color:var(--t3)}

/* ── Responsive ───────────────────────────────────────────── */
@media(max-width:900px){
  .sv-ep-layout{grid-template-columns:1fr}
  .sv-ep-sidebar{display:none}
  .sv-foot-grid{grid-template-columns:1fr 1fr;gap:28px}
  .sv-profile-hero{flex-direction:column;gap:16px}
  .sv-plat-hero{flex-direction:column;align-items:flex-start}
  .sv-grid{grid-template-columns:repeat(3,1fr);gap:16px}
}
@media(max-width:640px){
  #sv-header{padding:0 14px;gap:10px}
  .sv-hnav{display:none}
  .sv-search-trigger{display:none}
  .sv-hbtn-text{display:none}
  .sv-wrap{padding:0 14px}
  .sv-section{padding:20px 0}
  .sv-grid{grid-template-columns:repeat(1,1fr);gap:14px}
  .sv-pgrid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}
  .sv-plat-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
  .sv-ep-title{font-size:18px}
  .sv-profile-name{font-size:20px}
  .sv-foot-grid{grid-template-columns:1fr}
  #sv-mob-nav{display:flex}
  #sv-mob-search-btn{display:flex!important}
  body{padding-bottom:56px}
}

/* ── Card link structure fix ──────────────────────────────── */
/* Card uses two <a> tags: one wraps the thumb, one wraps the body.
   The article itself is the hover target via CSS :hover on .sv-card */
.sv-card { position: relative; }
.sv-card-link { display: block; text-decoration: none; }
.sv-card-body-link { display: block; text-decoration: none; }
.sv-card-fav { position: absolute; top: 8px; right: 8px; z-index: 2; }

/* ── Single episode page fav button ──────────────────────────
   Overrides .sv-card-fav (which is opacity:0 by default)
   when used as a standalone action button on the episode page */
.sv-ep-actions .sv-card-fav-btn {
  position: static;
  width: auto;
  height: auto;
  border-radius: var(--r8);
  opacity: 1;
  border: 1px solid var(--line2);
  background: var(--bg3);
  color: var(--t1);
  padding: 10px 16px;
  font-size: 13px;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  backdrop-filter: none;
  transition: all .15s;
}
.sv-ep-actions .sv-card-fav-btn:hover { background: var(--bg4); border-color: var(--line3); }
.sv-ep-actions .sv-card-fav-btn.on    { background: rgba(229,72,58,.12); border-color: rgba(229,72,58,.35); color: var(--red2); }
.sv-ep-actions .sv-card-fav-btn.on svg { fill: var(--red2); stroke: var(--red2); }

/* ── Critical: ensure dark background always shows ───────────
   Prevents white flash even if fonts/assets are slow to load */
html, body {
  background-color: #0c0c0e !important;
  min-height: 100vh;
}

/* ── Fix: page-templates in /templates/ subfolder ────────────
   WordPress sometimes doesn't pick up the template, so we
   ensure the body always has the dark background regardless */
.page-template-templates-page-home,
.page-template-templates-page-popular,
.page-template-templates-page-favorites,
.page-template-templates-page-actresses,
.page,
.single-episode,
.tax-platform,
.tax-series,
.tax-actress,
.tax-genre,
.post-type-archive-episode {
  background: var(--bg) !important;
}

/* ── Series Info Card (single episode page) ──────────────────
   Shows series name, platform, cast, episode count above
   the episode strip list                                    */
.sv-series-info-card{
  display:flex;
  gap:20px;
  align-items:flex-start;
  background:var(--bg2);
  border:1px solid var(--line2);
  border-radius:var(--r16);
  padding:20px;
  margin-bottom:0;
  margin-top:28px;
}
.sv-sic-left{ flex-shrink:0; }
.sv-sic-thumb{
  width:120px;
  height:68px;
  border-radius:var(--r8);
  background:var(--bg3);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  flex-shrink:0;
}
.sv-sic-body{
  flex:1;
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.sv-sic-title{
  font-size:17px;
  font-weight:800;
  color:var(--t1);
  letter-spacing:-.3px;
  text-decoration:none;
  line-height:1.3;
}
.sv-sic-title:hover{ color:var(--red2); }
.sv-sic-meta{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:6px;
}
.sv-sic-tag{
  display:inline-flex;
  align-items:center;
  background:var(--bg3);
  border:1px solid var(--line2);
  border-radius:var(--r4);
  padding:3px 10px;
  font-size:11px;
  font-weight:600;
  color:var(--t2);
}
.sv-sic-tag-red{
  background:rgba(229,72,58,.15);
  border-color:rgba(229,72,58,.3);
  color:var(--red2);
  text-decoration:none;
}
.sv-sic-tag-red:hover{ background:rgba(229,72,58,.25); }
.sv-sic-cast{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:6px;
  font-size:12px;
}
.sv-sic-cast-label{
  color:var(--t3);
  font-weight:600;
}
.sv-sic-cast-link{
  color:var(--t2);
  font-weight:500;
  text-decoration:none;
  transition:color .15s;
}
.sv-sic-cast-link:hover{ color:var(--t1); }
.sv-sic-cast-link:not(:last-child)::after{
  content:', ';
  color:var(--t3);
}
.sv-sic-btn-all{
  display:inline-flex;
  align-items:center;
  font-size:12px;
  font-weight:600;
  color:var(--red2);
  text-decoration:none;
  transition:color .15s;
  margin-top:2px;
}
.sv-sic-btn-all:hover{ color:var(--red); }

/* Mobile: stack thumb and body */
@media(max-width:640px){
  .sv-series-info-card{ flex-direction:column; gap:14px; }
  .sv-sic-thumb{ width:100%; height:auto; aspect-ratio:16/9; }
}

/* Also tighten the ser-strip when it follows the info card */
.sv-series-info-card + .sv-ser-strip{ margin-top:0; border-top:1px solid var(--line); }

/* ── Episode Info Row (single episode page) ──────────────────
   Clean label/value grid for series, actress, platform etc. */
.sv-ep-inforow{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
  gap:0;
  border:1px solid var(--line2);
  border-radius:var(--r12);
  overflow:hidden;
  margin:14px 0 20px;
  background:var(--bg2);
}
.sv-ep-infoitem{
  display:flex;
  flex-direction:column;
  padding:12px 16px;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  gap:4px;
}
.sv-ep-infoitem:last-child{border-right:none}
.sv-ep-infolabel{
  font-size:10px;
  font-weight:700;
  color:var(--t3);
  text-transform:uppercase;
  letter-spacing:.07em;
  line-height:1;
}
.sv-ep-infovalue{
  font-size:13px;
  font-weight:600;
  color:var(--t1);
  line-height:1.3;
}
.sv-ep-infolink{
  text-decoration:none;
  color:var(--t1);
  transition:color .15s;
}
.sv-ep-infolink:hover{color:var(--red2)}

/* Action buttons gap fix */
.sv-ep-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  align-items:center;
}
.sv-ep-actions .sv-btn-watch,
.sv-ep-actions .sv-btn-ghost{
  display:inline-flex;
  align-items:center;
  gap:6px;
  white-space:nowrap;
}

@media(max-width:640px){
  .sv-ep-inforow{grid-template-columns:repeat(2,1fr)}
  .sv-ep-infoitem{border-right:none;border-bottom:1px solid var(--line)}
  .sv-ep-infoitem:nth-child(odd){border-right:1px solid var(--line)}
}

/* ── Card actress name row ───────────────────────────────── */
.sv-card-actress{
  font-size:10px;
  color:var(--t3);
  margin-top:3px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* ── Tags section below action buttons ───────────────────── */
.sv-ep-tags-section {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 14px;
}
.sv-ep-tags-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--t3);
  text-transform: uppercase;
  letter-spacing: .06em;
  padding-top: 4px;
  white-space: nowrap;
  flex-shrink: 0;
}
.sv-ep-tags-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.sv-ep-tag-link {
  text-decoration: none;
  transition: background .15s, color .15s;
}
.sv-ep-tag-link:hover {
  background: var(--bg4);
  color: var(--t1);
  border-color: var(--line3);
}
.sv-tags-toggle {
  height: 28px;
  padding: 0 12px;
  border-radius: var(--r4);
  background: var(--bg3);
  border: 1px solid var(--line2);
  font-size: 11px;
  font-weight: 700;
  color: var(--red2);
  cursor: pointer;
  transition: all .15s;
  font-family: var(--f);
  white-space: nowrap;
}
.sv-tags-toggle:hover {
  background: var(--bg4);
  border-color: var(--line3);
}

/* ── Card platform link ───────────────────────────────────── */
.sv-card-plat-link{
  color:var(--t3);
  text-decoration:none;
  font-size:12px;
  transition:color .15s;
}
.sv-card-plat-link:hover{ color:var(--red2); }


/* ── Card info bar ────────────────────────────────────────── */
.sv-card-infobar{
  position:absolute;
  bottom:0;left:0;right:0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:5px 8px 7px;
  background:linear-gradient(0deg,rgba(0,0,0,.82) 0%,transparent 100%);
  z-index:1;
  gap:4px;
}
.sv-card-infobar-left{
  display:flex;align-items:center;gap:5px;min-width:0;flex:1;
}
.sv-card-infobar-plat{
  font-size:10px;font-weight:700;color:#fff;
  text-decoration:none;
  background:var(--red);
  padding:2px 7px;border-radius:3px;
  white-space:nowrap;flex-shrink:0;
  transition:background .15s;
  line-height:1.4;
}
.sv-card-infobar-plat:hover{background:var(--red2);}
.sv-card-infobar-ep{
  font-size:10px;font-weight:600;
  color:rgba(255,255,255,.75);
  white-space:nowrap;
}
.sv-card-infobar-right{flex-shrink:0;}
.sv-card-infobar-new{
  font-size:9px;font-weight:800;color:#fff;
  background:var(--red);
  padding:2px 7px;border-radius:3px;
  text-transform:uppercase;letter-spacing:.05em;
  line-height:1.4;
}
.sv-card-infobar-time{
  font-size:10px;font-weight:500;
  color:rgba(255,255,255,.65);
  white-space:nowrap;
}

/* Platform link in card meta row (if used elsewhere) */
.sv-card-plat-link{
  color:var(--t3);text-decoration:none;
  font-size:12px;transition:color .15s;
}
.sv-card-plat-link:hover{color:var(--red2);}

/* ── All Tags hub page ───────────────────────────────────── */
.sv-tags-hub{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding-top:8px;
}
.sv-tags-hub-item{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:8px 16px;
  background:var(--bg2);
  border:1px solid var(--line2);
  border-radius:var(--r8);
  font-size:13px;
  font-weight:600;
  color:var(--t2);
  text-decoration:none;
  transition:all .15s;
}
.sv-tags-hub-item:hover{
  background:var(--bg3);
  border-color:var(--line3);
  color:var(--t1);
}
.sv-tags-hub-item svg{
  color:var(--t3);
  flex-shrink:0;
}
.sv-tags-hub-count{
  font-size:11px;
  font-weight:500;
  color:var(--t3);
  background:var(--bg3);
  padding:1px 7px;
  border-radius:100px;
  margin-left:2px;
}
.sv-tags-hub-item:hover .sv-tags-hub-count{
  background:var(--bg4);
}

/* ── Tag extra items hidden by default ───────────────────── */
.sv-tag-extra { display: none; }

/* ── Single episode page tag pills ───────────────────────── */
.sv-single-tag {
  display: inline-flex;
  align-items: center;
  background: var(--bg3);
  border: 1px solid var(--line2);
  border-radius: var(--r4);
  padding: 3px 10px;
  font-size: 11px;
  font-weight: 600;
  color: var(--t2);
  text-decoration: none;
  transition: border-color .15s, color .15s;
}
.sv-single-tag:hover {
  border-color: var(--line3);
  color: var(--t1);
}
/* Extra tags hidden by default — NO conflict with other classes */
.sv-single-tag-extra {
  display: none;
}

/* ── Custom logo image in header ─────────────────────────── */
.sv-logo-img {
  height: 36px;
  width: auto;
  max-width: 160px;
  object-fit: contain;
  display: block;
}

/* ── Logo title beside icon ──────────────────────────────── */
.sv-logo-title {
  font-size: 17px;
  font-weight: 800;
  letter-spacing: -.4px;
  color: var(--t1);
  white-space: nowrap;
}

/* ── Play button hover scale ─────────────────────────────── */
.sv-card:hover .sv-card-play {
  transform: scale(1.1);
  background: var(--red2);
}

/* ── Visually hidden (SEO / accessibility) ───────────────── */
/* Hides text visually but keeps it readable by screen readers
   and search engine crawlers */
.sv-visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* ── Archive page header ─────────────────────────────────── */
.sv-archive-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 20px;
  gap: 12px;
  flex-wrap: wrap;
}
.sv-archive-title {
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -.4px;
  color: var(--t1);
  margin: 0 0 4px;
}
.sv-archive-count {
  font-size: 12px;
  color: var(--t3);
  margin: 0;
}

/* ── OTT pill wrap — gradient fade on right ──────────────── */
.sv-ott-wrap {
  position: relative;
  margin-bottom: 24px;
}
.sv-ott-wrap::after {
  content: '';
  position: absolute;
  top: 0; right: 0; bottom: 4px;
  width: 40px;
  background: linear-gradient(90deg, transparent, var(--bg));
  pointer-events: none;
}

/* ── 4-column grid for archive/latest pages ──────────────── */
.sv-grid-4 {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(4, 1fr);
}
@media (max-width: 1100px) {
  .sv-grid-4 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 700px) {
  .sv-grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 440px) {
  .sv-grid-4 { grid-template-columns: repeat(1, 1fr); }
}

/* ── Episode post date ───────────────────────────────────── */
.sv-ep-date {
  font-size: 12px;
  color: var(--t3);
  margin: 4px 0 16px;
}


/* ══════════════════════════════════════════════════════════
   EPISODE INFO PANEL — Redesigned compact & beautiful
══════════════════════════════════════════════════════════ */

/* Top badges row */
.sv-ep-tags {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}
.sv-ep-plat-tag {
  background: var(--red);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: var(--r4);
  text-decoration: none;
  letter-spacing: .02em;
}
.sv-ep-dur-tag {
  background: var(--bg3);
  color: var(--t2);
  font-size: 11px;
  font-weight: 500;
  padding: 3px 10px;
  border-radius: var(--r4);
  border: 1px solid var(--line2);
}
.sv-ep-new-tag {
  background: rgba(229,72,58,.15);
  border: 1px solid rgba(229,72,58,.35);
  color: var(--red2);
  font-size: 11px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: var(--r4);
  letter-spacing: .04em;
  text-transform: uppercase;
}

/* Episode title */
.sv-ep-title {
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -.4px;
  line-height: 1.25;
  margin: 0 0 10px;
  color: var(--t1);
}

/* Series badge — with background */
.sv-ep-series-badge {
  display: inline-flex;
  margin-bottom: 6px;
}
.sv-ep-series-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  color: var(--t2);
  text-decoration: none;
  background: var(--bg3);
  border: 1px solid var(--line2);
  border-radius: var(--r4);
  padding: 4px 10px;
  transition: all .15s;
}
.sv-ep-series-link:hover {
  background: var(--bg4);
  border-color: var(--line3);
  color: var(--t1);
}
.sv-ep-series-link svg {
  flex-shrink: 0;
  color: var(--t3);
}

/* Post date */
.sv-ep-date {
  font-size: 11px;
  color: var(--t4);
  margin: 0 0 16px;
}

/* Actress row */
.sv-ep-actress-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px !important;
}
.sv-ep-actress-row .sv-btn-ghost {
  font-size: 12px;
  padding: 7px 13px;
  gap: 5px;
}

/* Action buttons row */
.sv-ep-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 16px;
  align-items: center;
}
.sv-ep-actions .sv-btn-watch {
  font-size: 13px;
  padding: 9px 20px;
}
.sv-ep-actions .sv-btn-ghost {
  font-size: 13px;
  padding: 9px 16px;
}

@media (max-width:640px) {
  .sv-ep-title { font-size: 18px; }
  .sv-ep-actress-row .sv-btn-ghost,
  .sv-ep-actions .sv-btn-ghost,
  .sv-ep-actions .sv-btn-watch { font-size: 12px; padding: 8px 12px; }
}

/* ── Skip to content link (accessibility) ────────────────── */
.sv-skip-link {
  position: absolute;
  top: -100px;
  left: 16px;
  z-index: 9999;
  background: var(--red);
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  padding: 10px 20px;
  border-radius: var(--r8);
  text-decoration: none;
  transition: top .15s;
}
.sv-skip-link:focus {
  top: 16px;
}

/* ── All Series hub page ─────────────────────────────────── */
.sv-series-hub-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.sv-series-hub-card {
  position: relative;
  text-decoration: none;
  border-radius: var(--r8);
  overflow: hidden;
  background: var(--bg2);
  border: 1px solid var(--line2);
  transition: border-color .15s, transform .2s var(--ease);
  display: flex;
  flex-direction: column;
}
.sv-series-hub-card:hover {
  border-color: var(--line3);
  transform: translateY(-3px);
}
.sv-series-hub-thumb {
  position: relative;
  aspect-ratio: 16/9;
  background: var(--bg3);
  overflow: hidden;
  flex-shrink: 0;
}
.sv-series-hub-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .35s var(--ease);
}
.sv-series-hub-card:hover .sv-series-hub-thumb img {
  transform: scale(1.05);
}
.sv-series-hub-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--t4);
}
.sv-series-hub-count {
  position: absolute;
  bottom: 7px;
  right: 7px;
  background: rgba(0,0,0,.75);
  color: var(--t2);
  font-size: 10px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: var(--r4);
}
.sv-series-hub-info {
  padding: 10px 12px 12px;
}
.sv-series-hub-name {
  font-size: 13px;
  font-weight: 700;
  color: var(--t1);
  margin-bottom: 3px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sv-series-hub-plat {
  font-size: 11px;
  color: var(--t3);
}

@media (max-width: 900px) {
  .sv-series-hub-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 600px) {
  .sv-series-hub-grid { grid-template-columns: repeat(2, 1fr); }
}


/* ── Mobile More popup ───────────────────────────────────── */
.sv-mob-more-overlay {
  position: fixed;
  inset: 0;
  z-index: 9000;
  pointer-events: none;
  display: flex;
  align-items: flex-end;
}
.sv-mob-more-overlay.open {
  pointer-events: all;
}
.sv-mob-more-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.65);
  opacity: 0;
  transition: opacity .3s;
}
.sv-mob-more-overlay.open .sv-mob-more-backdrop {
  opacity: 1;
}
.sv-mob-more-sheet {
  position: relative;
  width: 100%;
  background: var(--bg2);
  border-top: 1px solid var(--line2);
  border-radius: 20px 20px 0 0;
  padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 72px);
  transform: translateY(100%);
  transition: transform .32s cubic-bezier(.32,1,.32,1);
  z-index: 1;
}
.sv-mob-more-overlay.open .sv-mob-more-sheet {
  transform: translateY(0);
}
.sv-mob-more-handle {
  width: 40px;
  height: 4px;
  border-radius: 2px;
  background: var(--line3);
  margin: 12px auto 0;
}
.sv-mob-more-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px 12px;
  border-bottom: 1px solid var(--line2);
}
.sv-mob-more-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--t2);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.sv-mob-more-close {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--bg3);
  border: 1px solid var(--line2);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--t2);
  cursor: pointer;
  transition: background .15s;
}
.sv-mob-more-close:hover { background: var(--bg4); }
.sv-mob-more-links { padding: 6px 0; }
.sv-mob-more-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  font-size: 15px;
  font-weight: 600;
  color: var(--t1);
  text-decoration: none;
  transition: background .1s;
  position: relative;
}
.sv-mob-more-item + .sv-mob-more-item {
  border-top: 1px solid var(--line2);
}
.sv-mob-more-item:active { background: var(--bg3); }
.sv-mob-more-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: var(--bg3);
  border: 1px solid var(--line2);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--red2);
  flex-shrink: 0;
}
.sv-mob-more-arrow { color: var(--t4); margin-left: auto; flex-shrink: 0; }
.sv-mob-more-count {
  font-size: 11px;
  font-weight: 700;
  background: var(--red);
  color: #fff;
  padding: 2px 8px;
  border-radius: 100px;
  min-width: 20px;
  text-align: center;
}


/* ── Views badge with eye icon ───────────────────────────── */
.sv-views-badge,
.sv-card-infobar-ep {
  display: inline-flex !important;
  align-items: center;
  gap: 4px;
}
.sv-views-badge svg,
.sv-card-infobar-ep svg {
  flex-shrink: 0;
  opacity: .7;
}


/* ── Actress profile page avatar img ─────────────────────── */
.sv-profile-av-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  border-radius: inherit;
}


/* ══════════════════════════════════════════════════════════
   ACTRESS CARD — Image top, info below
══════════════════════════════════════════════════════════ */
.sv-pcard {
  display: block;
  text-decoration: none;
  border-radius: 12px;
  overflow: hidden;
  background: var(--bg2);
  border: 1px solid var(--line2);
  transition: transform .2s var(--ease), border-color .2s, box-shadow .2s;
}
.sv-pcard:hover {
  transform: translateY(-4px);
  border-color: var(--line3);
  box-shadow: 0 8px 24px rgba(0,0,0,.4);
}

/* Image section */
.sv-pcard-img-wrap {
  position: relative;
  position: relative;
  width: 100%;
  aspect-ratio: 3/4;
  overflow: hidden;
  background: var(--bg3);
}
.sv-pcard-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  transition: transform .4s var(--ease);
}
.sv-pcard:hover .sv-pcard-img {
  transform: scale(1.05);
}
.sv-pcard-img-default {
  object-position: center top;
}

/* Info section below image */
.sv-pcard-body {
  padding: 10px 12px 12px;
  background: var(--bg2);
  border-top: 1px solid var(--line2);
}
.sv-pcard-name {
  font-size: 13px;
  font-weight: 700;
  color: var(--t1);
  margin-bottom: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sv-pcard-count {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 500;
  color: var(--t3);
}
.sv-pcard-count svg {
  flex-shrink: 0;
  color: var(--red);
}

/* Horizontal scroll */
.sv-hscroll .sv-pcard { flex-shrink: 0; width: 130px; }

/* ── Desktop nav links with Iconify icons ────────────────── */
.sv-hnav-link {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  color: var(--t2);
  text-decoration: none;
  padding: 6px 8px;
  border-radius: var(--r4);
  transition: color .15s, background .15s;
  white-space: nowrap;
}
.sv-hnav-link iconify-icon {
  font-size: 16px;
  color: var(--t3);
  transition: color .15s;
  flex-shrink: 0;
}
.sv-hnav-link:hover,
.sv-hnav-link.current {
  color: var(--t1);
}
.sv-hnav-link:hover iconify-icon,
.sv-hnav-link.current iconify-icon {
  color: var(--red);
}
.sv-hnav-link.current {
  color: var(--red);
}

/* ── Nav icon — raw SVG from description field ───────────── */
.sv-nav-icon-svg {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  color: var(--t3);
  transition: color .15s;
}
.sv-nav-icon-svg svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}
.sv-hnav-link:hover .sv-nav-icon-svg,
.sv-hnav-link.current .sv-nav-icon-svg {
  color: var(--red);
}

/* ── Series info boxes (cast + about) ────────────────────── */
.sv-series-info-box {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: var(--bg2);
  border: 1px solid var(--line2);
  border-radius: var(--r8);
  padding: 12px 16px;
  margin-bottom: 10px;
}
.sv-series-box-label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 700;
  color: var(--t3);
  text-transform: uppercase;
  letter-spacing: .06em;
  white-space: nowrap;
  flex-shrink: 0;
  padding-top: 1px;
}
.sv-series-box-label svg { flex-shrink: 0; }
.sv-series-box-sep {
  width: 1px;
  height: 16px;
  background: var(--line2);
  flex-shrink: 0;
  margin-top: 1px;
}
.sv-series-cast-names {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.sv-series-cast-link {
  font-size: 13px;
  font-weight: 500;
  color: var(--t1);
  text-decoration: none;
  transition: color .15s;
}
.sv-series-cast-link:hover { color: var(--red2); }
.sv-series-cast-dot { color: var(--t4); font-size: 12px; }

/* About box */
.sv-series-about-box { flex-direction: column; gap: 8px; }
.sv-series-about-text {
  font-size: 13px;
  color: var(--t2);
  line-height: 1.7;
  margin: 0;
}
.sv-series-about-toggle {
  background: none;
  border: none;
  padding: 0 0 0 4px;
  font-size: 13px;
  font-weight: 600;
  color: var(--red2);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.sv-series-about-toggle:hover { color: var(--t1); }

@media (max-width: 640px) {
  .sv-series-hero { flex-direction: column; min-height: auto; }
  .sv-series-hero-thumb { width: 100%; aspect-ratio: 16/9; }
  .sv-series-hero-info { padding: 14px; }
  .sv-series-hero-title { font-size: 17px; }
}

/* ══════════════════════════════════════════════════════════
   SERIES PAGE — Complete
══════════════════════════════════════════════════════════ */

/* Hero box */
.sv-series-hero {
  display: flex;
  align-items: stretch;
  background: var(--bg2);
  border: 1px solid var(--line2);
  border-radius: var(--r12);
  overflow: hidden;
  margin-bottom: 10px;
}
/* Thumbnail — no overflow:hidden so corners never cut */
.sv-series-hero-thumb {
  flex-shrink: 0;
  width: 300px;
  min-height: 140px;
  background: var(--bg3);
  display: flex;
  align-items: center;
  justify-content: center;
}
.sv-series-hero-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}
.sv-series-hero-no-thumb {
  color: var(--t4);
}

/* Info panel */
.sv-series-hero-info {
  flex: 1;
  min-width: 0;
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 12px;
}
.sv-series-hero-top {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.sv-series-hero-title {
  font-size: 20px;
  font-weight: 800;
  color: var(--t1);
  margin: 0;
  letter-spacing: -.3px;
  line-height: 1.3;
}
.sv-series-hero-plat { flex-shrink: 0; }

/* Meta pills */
.sv-series-hero-meta {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.sv-series-meta-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  color: var(--t2);
  background: var(--bg3);
  border: 1px solid var(--line2);
  border-radius: 100px;
  padding: 3px 10px;
  white-space: nowrap;
}
.sv-series-meta-pill svg { flex-shrink: 0; color: var(--t3); }

/* Play button */
.sv-series-play-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  font-size: 13px !important;
  padding: 9px 20px !important;
}

/* Cast + About boxes */
.sv-series-info-box {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: var(--bg2);
  border: 1px solid var(--line2);
  border-radius: var(--r8);
  padding: 12px 16px;
  margin-bottom: 10px;
}
.sv-series-box-label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 700;
  color: var(--t3);
  text-transform: uppercase;
  letter-spacing: .06em;
  white-space: nowrap;
  flex-shrink: 0;
  padding-top: 2px;
}
.sv-series-box-label svg { flex-shrink: 0; }
.sv-series-box-sep {
  width: 1px;
  min-height: 16px;
  align-self: stretch;
  background: var(--line2);
  flex-shrink: 0;
}
.sv-series-cast-names {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.sv-series-cast-link {
  font-size: 13px;
  font-weight: 500;
  color: var(--t1);
  text-decoration: none;
  transition: color .15s;
}
.sv-series-cast-link:hover { color: var(--red2); }
.sv-series-cast-dot { color: var(--t4); font-size: 12px; }

/* About box */
.sv-series-about-box { flex-direction: column; gap: 8px; }
.sv-series-about-text {
  font-size: 13px;
  color: var(--t2);
  line-height: 1.7;
  margin: 0;
}
.sv-series-about-toggle {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: none;
  border: none;
  padding: 0 0 0 6px;
  font-size: 12px;
  font-weight: 600;
  color: var(--red2);
  cursor: pointer;
}
.sv-series-about-toggle:hover { color: var(--t1); }
.sv-series-about-toggle svg { flex-shrink: 0; transition: transform .2s; }
.sv-series-about-toggle.open svg { transform: rotate(180deg); }

/* Mobile */
@media (max-width: 680px) {
  .sv-series-hero {
    flex-direction: column;
  }
  .sv-series-hero-thumb {
    width: 100%;
    min-height: auto;
    aspect-ratio: 16/9;
  }
  .sv-series-hero-info {
    padding: 14px 14px 16px;
    gap: 10px;
  }
  .sv-series-hero-title { font-size: 17px; }
  .sv-series-meta-pill { font-size: 11px; padding: 3px 8px; }
  .sv-series-info-box {
    flex-wrap: wrap;
    gap: 8px;
  }
  .sv-series-box-sep { display: none; }
  .sv-series-cast-names { width: 100%; }
}

/* Fix thumbnail corners — no clipping */
.sv-series-hero-wrap {
  overflow: visible !important;
  border-radius: var(--r12);
}
.sv-series-hero-thumb {
  border-radius: calc(var(--r12) - 1px) 0 0 calc(var(--r12) - 1px);
  overflow: hidden;
}
@media (max-width: 680px) {
  .sv-series-hero-thumb {
    border-radius: calc(var(--r12) - 1px) calc(var(--r12) - 1px) 0 0;
  }
}


/* ══════════════════════════════════════════════════════════
   FAVOURITES — Complete CSS
   sv-fav-btn   : small heart on cards
   sv-fav-btn-lg: large heart on profile pages
   sv-fav-tabs  : saved page tabs
   sv-series-card: series card
══════════════════════════════════════════════════════════ */

/* ── Heart button — card size ────────────────────────────── */
.sv-fav-btn {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: rgba(0,0,0,.55);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: background .2s, transform .15s;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
/* Card hearts — absolute positioned inside thumb */
.sv-pcard-img-wrap > .sv-fav-btn,
.sv-series-card-thumb > .sv-fav-btn,
.sv-series-hub-card > .sv-fav-btn,
.sv-card-thumb > .sv-fav-btn,
.sv-plat-card > .sv-fav-btn,
.sv-plat-card > .sv-fav-btn {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 2;
}
.sv-fav-btn svg {
  width: 14px;
  height: 14px;
  stroke: #fff;
  fill: none;
  transition: fill .2s, stroke .2s;
  flex-shrink: 0;
}
.sv-fav-btn:hover {
  background: rgba(232,0,13,.8);
  transform: scale(1.1);
}
.sv-fav-btn.on {
  background: var(--red);
}
.sv-fav-btn.on svg {
  fill: #fff;
  stroke: #fff;
}

/* ── Heart button — large (profile pages) ────────────────── */
.sv-fav-btn-lg {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--bg3);
  border: 1px solid var(--line2);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  flex-shrink: 0;
  transition: background .2s, border-color .2s, transform .15s;
}
.sv-fav-btn-lg svg {
  width: 16px;
  height: 16px;
  stroke: var(--t2);
  fill: none;
  transition: fill .2s, stroke .2s;
  flex-shrink: 0;
}
.sv-fav-btn-lg:hover {
  background: rgba(232,0,13,.1);
  border-color: var(--red);
  transform: scale(1.08);
}
.sv-fav-btn-lg:hover svg { stroke: var(--red); }
.sv-fav-btn-lg.on {
  background: rgba(232,0,13,.12);
  border-color: var(--red);
}
.sv-fav-btn-lg.on svg {
  fill: var(--red);
  stroke: var(--red);
}

/* ── Saved page — tabs ────────────────────────────────────── */
.sv-fav-tabs {
  display: flex;
  gap: 0;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--line2);
  margin-bottom: 24px;
}
.sv-fav-tab {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  padding: 10px 16px;
  font-size: 13px;
  font-weight: 600;
  color: var(--t3);
  cursor: pointer;
  transition: color .15s, border-color .15s;
  margin-bottom: -1px;
  white-space: nowrap;
}
.sv-fav-tab:hover { color: var(--t1); }
.sv-fav-tab.active {
  color: var(--t1);
  border-bottom-color: var(--red);
}
.sv-fav-tab svg { flex-shrink: 0; }
.sv-fav-tab-count {
  background: var(--bg3);
  border-radius: 100px;
  font-size: 11px;
  font-weight: 700;
  padding: 1px 8px;
  color: var(--t3);
  min-width: 20px;
  text-align: center;
}
.sv-fav-tab.active .sv-fav-tab-count {
  background: var(--red);
  color: #fff;
}

/* ── Saved page — panels ─────────────────────────────────── */
.sv-fav-panel { min-height: 180px; }
.sv-fav-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  min-height: 180px;
  color: var(--t4);
  text-align: center;
}
.sv-fav-empty p {
  font-size: 14px;
  color: var(--t3);
  margin: 0;
}

/* ── Series card ─────────────────────────────────────────── */
.sv-series-card {
  display: block;
  text-decoration: none;
  border-radius: var(--r12);
  overflow: hidden;
  background: var(--bg2);
  border: 1px solid var(--line2);
  transition: transform .2s var(--ease), border-color .2s, box-shadow .2s;
}
.sv-series-card:hover {
  transform: translateY(-3px);
  border-color: var(--line3);
  box-shadow: 0 6px 20px rgba(0,0,0,.3);
}
.sv-series-card-thumb {
  position: relative;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--bg3);
}
.sv-series-card-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .35s var(--ease);
}
.sv-series-card:hover .sv-series-card-thumb img { transform: scale(1.05); }
.sv-series-card-no-img {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--t4);
}
.sv-series-card-body {
  padding: 10px 12px 12px;
}
.sv-series-card-name {
  font-size: 13px;
  font-weight: 700;
  color: var(--t1);
  margin-bottom: 3px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sv-series-card-eps { font-size: 11px; color: var(--t3); }
.sv-card-plat-badge {
  position: absolute;
  bottom: 8px;
  left: 8px;
  background: var(--red);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 4px;
  pointer-events: none;
}

/* Mobile */
@media (max-width: 600px) {
  .sv-fav-tab { padding: 8px 10px; font-size: 12px; }
  .sv-fav-tab-count { display: none; }
}

.sv-fav-btn-cancel svg {
  stroke: #fff !important;
  fill: none !important;
  width: 13px !important;
  height: 13px !important;
}
.sv-fav-btn-cancel:hover {
  background: rgba(180,0,0,.95) !important;
  transform: scale(1.1);
}

/* ── Episode page fav label ──────────────────────────────── */
.sv-fav-label {
  font-size: 13px;
  font-weight: 500;
}
.sv-card-fav-btn.on .sv-fav-label {
  color: var(--red2);
}

/* ── Legal / Standard Pages ──────────────────────────────── */
.sv-legal-page {
  max-width: 780px;
  margin: 0 auto;
}
.sv-legal-header {
  margin-bottom: 32px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--line2);
}
.sv-legal-title {
  font-size: 32px;
  font-weight: 800;
  color: var(--t1);
  margin: 0 0 8px;
  letter-spacing: -.4px;
}
.sv-legal-updated {
  font-size: 13px;
  color: var(--t3);
  margin: 0;
}
.sv-legal-content {
  font-size: 15px;
  line-height: 1.8;
  color: var(--t2);
}
.sv-legal-content h2 {
  font-size: 20px;
  font-weight: 700;
  color: var(--t1);
  margin: 36px 0 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--line2);
}
.sv-legal-content p {
  margin: 0 0 16px;
}
.sv-legal-content ul,
.sv-legal-content ol {
  padding-left: 24px;
  margin: 0 0 16px;
}
.sv-legal-content li {
  margin-bottom: 8px;
}
.sv-legal-content a {
  color: var(--red2);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.sv-legal-content a:hover { color: var(--t1); }
.sv-legal-content strong { color: var(--t1); font-weight: 600; }

@media (max-width: 640px) {
  .sv-legal-title { font-size: 24px; }
  .sv-legal-content { font-size: 14px; }
}
