*{margin:0;padding:0;box-sizing:border-box}

/* ═══════════════════════════════════════════════
   CEED DESIGN SYSTEM — Light (default) + Dark
   ═══════════════════════════════════════════════ */
:root{
  --accent:#0C9B8D;--accent-d:#088078;--accent-l:#D0F7F0;
  --gold:#C99312;--gold-l:#FDF4D8;
  --red:#C53434;--red-l:#FDE2E2;
  --green:#169649;--green-l:#D2F9DF;
  --blue:#2D65D9;--blue-l:#DBEAFE;
  --violet:#6E42C9;--violet-l:#EBE2F9;
  --pink:#BE3F8E;--orange:#D97B0B;
  --bg:#FAFAFA;--bg2:#FAFAFA;--bg3:#F0F0F2;--bg4:#E2E5ED;
  --tx:#111;--tx2:#555;--tx3:#999;--txl:#BBB;
  --border:#E8E8E8;
  --card:#FAFAFA;
  --shadow:none;
  --shadow-hover:none;
  --shadow-lg:0 20px 60px rgba(0,0,0,.12),0 4px 16px rgba(0,0,0,.06);
  --r:0;--r-sm:6px;--r-btn:20px;
  --font:'Montserrat',sans-serif;--mono:'JetBrains Mono',monospace;
  --header-bg:rgba(255,255,255,.92);
  --overlay:rgba(0,0,0,.4);
  --shimmer-a:#ECEEF4;--shimmer-b:#E2E5ED;
}

[data-theme="dark"]{
  --bg:#0A0A0F;--bg2:#111118;--bg3:#1A1A24;--bg4:#222230;
  --tx:#F0F0F5;--tx2:#8B8B9E;--tx3:#666680;--txl:#444458;
  --border:#1E1E2A;
  --card:#0A0A0F;
  --shadow:none;
  --shadow-hover:none;
  --shadow-lg:0 20px 60px rgba(0,0,0,.5),0 4px 16px rgba(0,0,0,.3);
  --header-bg:rgba(22,27,34,.92);
  --overlay:rgba(0,0,0,.7);
  --accent-l:rgba(12,155,141,.15);--gold-l:rgba(201,147,18,.15);
  --red-l:rgba(197,52,52,.15);--green-l:rgba(22,150,73,.15);
  --blue-l:rgba(45,101,217,.15);--violet-l:rgba(110,66,201,.15);
  --shimmer-a:#1C2128;--shimmer-b:#21262D;
}

/* ═══ Channel accent colors ═══ */
[data-theme][data-channel="videos"]{--accent:#0C9B8D;--accent-d:#088078;--accent-l:rgba(12,155,141,.15)}
[data-theme][data-channel="movies"]{--accent:#C9A227;--accent-d:#A8871E;--accent-l:rgba(201,162,39,.15)}
[data-theme][data-channel="music"],[data-theme][data-channel="podcast"]{--accent:#8B5CF6;--accent-d:#7C3AED;--accent-l:rgba(139,92,246,.15)}
[data-theme][data-channel="seeds"]{--accent:#22C55E;--accent-d:#16A34A;--accent-l:rgba(34,197,94,.15)}
[data-theme][data-channel="sports"]{--accent:#EF4444;--accent-d:#DC2626;--accent-l:rgba(239,68,68,.15)}
[data-theme][data-channel="live"]{--accent:#F43F5E;--accent-d:#E11D48;--accent-l:rgba(244,63,94,.15)}
[data-theme][data-channel="discuss"]{--accent:#3B82F6;--accent-d:#2563EB;--accent-l:rgba(59,130,246,.15)}
[data-theme][data-channel="discover"]{--accent:#0C9B8D;--accent-d:#088078;--accent-l:rgba(12,155,141,.15)}

/* light mode removed — dark only */
html,body{height:100%;background:var(--bg);color:var(--tx);font-family:var(--font);overflow-x:hidden;-webkit-font-smoothing:antialiased}
body{transition:background .3s,color .3s}

/* ── Ambient gradient ── */
.ceed-ambient{display:none;position:fixed;inset:0;pointer-events:none;z-index:0;opacity:0}
@keyframes ambientShift{0%,100%{opacity:1}50%{opacity:.5}}

/* ═══ HEADER ═══ */
.vf-header{position:fixed;top:0;left:0;right:0;z-index:9000;background:var(--header-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);height:56px;display:flex;align-items:center;padding:0 24px;gap:12px;transition:transform .3s ease,opacity .3s ease}
.vf-header.cinema{transform:translateY(-100%);opacity:0;pointer-events:none}
/* Hide floating FABs — podcast + chat are in the header now */
#ceed-agent-fab{display:none!important}
#podFab{display:none!important}
.vf-header.cinema ~ .vf-main .hp-viz{border-radius:0}
.vf-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--tx);flex-shrink:0}
.vf-logo img{height:34px;width:34px;border-radius:10px}
.vf-logo-text{font-weight:800;font-size:16px;letter-spacing:-.02em}
.vf-logo-badge{padding:2px 7px;border-radius:5px;background:var(--accent-l);color:var(--accent);font-size:10px;font-weight:700;margin-left:4px}
.vf-search{flex:0 1 220px;position:relative}
.vf-search input{width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:7px 36px 7px 14px;color:#fff;font-family:var(--font);font-size:12px;outline:none;transition:border .2s,box-shadow .3s}
.vf-voice-btn{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:none;color:rgba(255,255,255,.35);font-size:14px;cursor:pointer;padding:4px;transition:color .2s}
.vf-voice-btn:hover{color:rgba(255,255,255,.7)}
.vf-voice-btn.listening{color:var(--accent);animation:voicePulse 1s ease infinite}
@keyframes voicePulse{0%,100%{opacity:1}50%{opacity:.4}}
.vf-search input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(12,155,141,.1)}
.vf-search input::placeholder{color:var(--txl)}
.vf-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--txl);font-size:14px}
.vf-search-results{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-lg);max-height:420px;overflow-y:auto;z-index:200;display:none}
.vf-search-results.show{display:block}
.vf-search-results .vf-sr-group{padding:8px 0}
.vf-search-results .vf-sr-group-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--tx3);padding:4px 14px 6px}
.vf-search-results .vf-sr-item{display:flex;align-items:center;gap:10px;padding:8px 14px;cursor:pointer;transition:background .1s}
.vf-search-results .vf-sr-item:hover{background:var(--accent-l)}
.vf-search-results .vf-sr-thumb{width:48px;height:28px;border-radius:4px;background:var(--bg3);flex-shrink:0;overflow:hidden}
.vf-search-results .vf-sr-thumb img{width:100%;height:100%;object-fit:cover}
.vf-search-results .vf-sr-info{flex:1;min-width:0}
.vf-search-results .vf-sr-title{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vf-search-results .vf-sr-meta{font-size:10px;color:var(--tx3)}
.vf-search-results .vf-sr-badge{font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;flex-shrink:0}
.vf-search-results .vf-sr-empty{padding:24px 14px;text-align:center;color:var(--tx3);font-size:12px}
.vf-header-actions{display:flex;gap:8px;align-items:center;margin-left:auto}

/* ═══ BUTTONS ═══ */
.vf-btn{padding:9px 18px;border-radius:var(--r-btn);border:none;cursor:pointer;font-family:var(--font);font-weight:600;font-size:13px;transition:all .15s;display:inline-flex;align-items:center;gap:6px;text-decoration:none}
.vf-btn-primary{background:none;color:var(--tx2);border:none;box-shadow:none;font-weight:700;font-size:13px;letter-spacing:.03em;padding:8px 4px;border-radius:0;transition:color .15s}
.vf-btn-primary:hover{background:none;color:#fff;box-shadow:none;transform:none}
.vf-btn-outline{background:transparent;color:var(--tx2);border:1px solid var(--border)}
.vf-sort-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.vf-btn-outline:hover{border-color:var(--accent);color:var(--accent)}
.vf-btn-gold{background:linear-gradient(135deg,#C99312,#E5A913);color:#fff}
.vf-btn-gold:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(201,147,18,.3)}
.vf-btn-sm{padding:6px 12px;font-size:12px;border-radius:var(--r-sm)}
.vf-btn-icon{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--r-btn);border:1px solid var(--border);background:var(--bg2);color:var(--tx2);cursor:pointer;font-size:16px;transition:all .15s}
.vf-btn-icon:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-l)}

/* ═══ AVATAR & BALANCE ═══ */
.vf-avatar{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--accent-d));color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;cursor:pointer;overflow:hidden;transition:transform .15s}
.vf-notif-badge{position:absolute;top:-4px;right:-4px;background:#FF4444;color:#fff;font-size:9px;font-weight:800;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.vf-notif-panel{position:fixed;top:56px;right:16px;width:360px;max-height:480px;background:rgba(22,27,34,.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:16px;box-shadow:0 8px 40px rgba(0,0,0,.4);z-index:300;display:none;flex-direction:column;overflow:hidden}
body.light .vf-notif-panel{background:rgba(255,255,255,.88);border:1px solid rgba(0,0,0,.06);box-shadow:0 8px 40px rgba(0,0,0,.1)}
.vf-notif-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.vf-notif-icon.tip{background:rgba(201,147,18,.15);color:var(--gold)}
.vf-notif-icon.unlock{background:var(--accent-l);color:var(--accent)}
.vf-notif-icon.booking{background:rgba(45,101,217,.15);color:var(--blue)}
.vf-notif-icon.video{background:rgba(110,66,201,.15);color:var(--violet)}
.vf-notif-icon.default{background:var(--bg3);color:var(--tx2)}
.vf-notif-row{display:flex;gap:10px;align-items:flex-start}
.vf-notif-content{flex:1;min-width:0}
.vf-notif-title{font-weight:600;font-size:13px;color:var(--tx);line-height:1.3}
.vf-notif-body{font-size:12px;color:var(--tx2);margin-top:2px;line-height:1.3}
.vf-notif-panel.show{display:flex}
.vf-notif-hdr{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-weight:700;font-size:14px}
.vf-notif-list{overflow-y:auto;flex:1;max-height:400px}
.vf-notif-item{padding:12px 16px;border-bottom:1px solid var(--border);font-size:13px;cursor:pointer;transition:background .1s}
.vf-notif-item:hover{background:var(--bg3)}
.vf-notif-item.unread{background:rgba(12,155,141,.06)}
.vf-notif-time{font-size:11px;color:var(--txl);margin-top:4px}
.vf-notif-amount{color:var(--gold);font-weight:700;font-family:var(--mono)}
.vf-notif-empty{padding:40px 16px;text-align:center;color:var(--txl);font-size:13px}
.vf-avatar:hover{transform:scale(1.05)}
.vf-avatar img{width:100%;height:100%;object-fit:cover}
.vf-balance{font-family:var(--mono);font-size:12px;color:var(--gold);background:var(--gold-l);padding:5px 12px;border-radius:var(--r-sm);font-weight:600}
.vf-ceed-ticker{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px;color:var(--accent);background:rgba(12,155,141,.1);padding:4px 10px;border-radius:var(--r-sm);font-weight:600;white-space:nowrap}
.vf-ceed-ticker a{color:var(--accent);text-decoration:none;font-weight:700;font-size:10px;border-left:1px solid rgba(12,155,141,.25);padding-left:6px;margin-left:2px}
.vf-ceed-ticker a:hover{text-decoration:underline}

/* ═══ MESSAGES PANEL ═══ */
.vf-msg-panel{position:fixed;top:56px;right:16px;width:380px;height:calc(100vh - 72px);max-height:600px;background:rgba(22,27,34,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:16px;box-shadow:0 8px 40px rgba(0,0,0,.5);z-index:300;display:none;flex-direction:column;overflow:hidden}
.vf-msg-panel.show{display:flex}
.vf-msg-hdr{padding:10px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;flex-shrink:0}
.vf-msg-hdr-title{font-size:14px;font-weight:800;flex:1}
.vf-msg-hdr button{background:none;border:none;color:var(--tx2);cursor:pointer;font-size:14px;padding:4px;border-radius:6px;transition:background .15s}
.vf-msg-hdr button:hover{background:rgba(255,255,255,.08)}
.vf-msg-list{flex:1;overflow-y:auto;scrollbar-width:none}
.vf-msg-list::-webkit-scrollbar{display:none}
.vf-msg-conv{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;border-bottom:1px solid rgba(255,255,255,.04);transition:background .12s}
.vf-msg-conv:hover{background:rgba(255,255,255,.04)}
.vf-msg-conv.unread{background:rgba(12,155,141,.06)}
.vf-msg-conv.active{background:rgba(12,155,141,.1);border-left:3px solid var(--accent)}
.vf-msg-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;overflow:hidden}
.vf-msg-avatar img{width:100%;height:100%;object-fit:cover}
.vf-msg-conv-info{flex:1;min-width:0}
.vf-msg-conv-name{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vf-msg-conv-last{font-size:10px;color:var(--tx3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.vf-msg-conv-time{font-size:9px;color:var(--tx3);flex-shrink:0}
.vf-msg-conv-badge{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0}
.vf-msg-thread{flex:1;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:6px;scrollbar-width:none}
.vf-msg-thread::-webkit-scrollbar{display:none}
.vf-msg-bubble{max-width:80%;padding:8px 12px;border-radius:14px;font-size:12px;line-height:1.4;word-wrap:break-word}
.vf-msg-bubble.mine{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:4px}
.vf-msg-bubble.theirs{align-self:flex-start;background:rgba(255,255,255,.08);color:var(--tx);border-bottom-left-radius:4px}
.vf-msg-bubble.agent{align-self:flex-start;background:rgba(201,147,18,.12);color:var(--tx);border:1px solid rgba(201,147,18,.2);border-bottom-left-radius:4px}
.vf-msg-bubble-time{font-size:8px;color:rgba(255,255,255,.3);margin-top:2px}
.vf-msg-input-wrap{padding:8px 10px;border-top:1px solid var(--border);display:flex;gap:6px;align-items:center;flex-shrink:0}
.vf-msg-input{flex:1;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:8px 14px;color:#fff;font-family:var(--font);font-size:12px;outline:none;resize:none;max-height:80px}
.vf-msg-input:focus{border-color:var(--accent)}
.vf-msg-send{background:var(--accent);color:#fff;border:none;border-radius:50%;width:32px;height:32px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;transition:opacity .15s}
.vf-msg-send:hover{opacity:.85}
.vf-msg-empty{padding:40px 16px;text-align:center;color:var(--tx3);font-size:12px}
@media(max-width:480px){
  .vf-msg-panel{width:calc(100vw - 16px)!important;right:8px!important;left:8px!important;max-height:calc(100vh - 64px)!important;border-radius:12px!important}
}

/* ═══ TABS ═══ */
.vf-tabs-wrap{display:none}
.vf-tabs{display:none}
/* Header nav tabs */
.vf-header-nav{display:flex;align-items:center;gap:0;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;flex:1;justify-content:space-evenly;padding-left:8px}
.vf-header-nav::-webkit-scrollbar{display:none}
.vf-header-nav .vf-tab{padding:8px 2px;border-radius:0;border:none;cursor:pointer;font-family:var(--font);font-size:13px;font-weight:500;background:none;color:rgba(255,255,255,.4);white-space:nowrap;transition:color .2s;position:relative;overflow:visible;letter-spacing:.01em}
.vf-header-nav .vf-tab:hover{color:rgba(255,255,255,.7)}
.vf-header-nav .vf-tab.active{color:#fff;font-weight:700}
.vf-header-nav .vf-tab.active::after{content:'';position:absolute;bottom:-2px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--accent);display:block}
.vf-header-nav .vf-tab .vf-tab-icon{display:none}
.vf-header-search-btn{background:none;border:none;color:rgba(255,255,255,.4);font-size:16px;cursor:pointer;padding:6px;transition:color .2s;flex-shrink:0}
.vf-header-search-btn:hover{color:#fff}
/* User menu button */
.vf-user-menu-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:var(--card);color:var(--tx);font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.vf-user-menu-btn:hover{border-color:var(--accent)}
.vf-user-menu{position:absolute;top:48px;right:0;background:var(--card);border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 40px rgba(0,0,0,.2);padding:6px;min-width:160px;display:none;z-index:200}
.vf-user-menu.show{display:block}
.vf-user-menu-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;cursor:pointer;font-size:12px;font-weight:600;color:var(--tx2);transition:background .12s;border:none;background:none;width:100%;font-family:var(--font)}
.vf-user-menu-item:hover{background:var(--bg3);color:var(--tx)}
/* Legacy tab styles — now in header nav */
.vf-tab{padding:8px 16px;border-radius:9px;border:none;cursor:pointer;font-family:var(--font);font-size:13px;font-weight:600;background:transparent;color:var(--tx3);white-space:nowrap;transition:all .15s}
.vf-tab:hover{color:var(--tx2);background:rgba(255,255,255,.5)}
[data-theme="dark"] .vf-tab:hover{background:rgba(255,255,255,.05)}
.vf-tab.active{background:var(--card);color:var(--tx);box-shadow:none}
[data-theme="dark"] .vf-tab.active{box-shadow:none}
.vf-tab{position:relative;overflow:visible}
.vf-tab canvas.tab-viz{display:none}
.vf-tab-icon{margin-right:5px}

/* ═══ MAIN ═══ */
.vf-main{margin-top:56px;padding:0 32px;max-width:1280px;margin-left:auto;margin-right:auto;position:relative;z-index:1;scroll-margin-top:56px;transition:margin-top .3s ease}
.vf-header.cinema ~ .vf-main{margin-top:0;padding-top:0}

/* ═══ SECTION HEADER ═══ */
.vf-section-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;margin-top:32px;padding:0 2px}
.vf-section-title{font-size:17px;font-weight:800;letter-spacing:-.02em}
.vf-section-more{font-size:12px;color:var(--accent);cursor:pointer;font-weight:600}
.vf-section-more:hover{text-decoration:underline}

/* ═══ YOUTUBE-STYLE DESIGN — grid, rounded thumbs, text below ═══ */

/* ── Cards: borderless, no shadow, transparent ── */
.vf-card,.vf-card-new,.suno-track,[data-liveidx],[data-cwqid],
#seedCompose,.vf-upnext-card,.s-grid-card,.s-match-card,
.vf-stat-tile,#createPlaylistForm,#podcastPlayer {
  border:none!important;box-shadow:none!important;background:transparent!important
}
/* ── Hover: synced with Hero Player shadow visualizer ── */
:root{--glow-r:180;--glow-g:80;--glow-b:200;--glow-r2:60;--glow-g2:100;--glow-b2:200;--glow-energy:0.5}
.vf-card,.vf-card-new,[data-liveidx],.s-grid-card{transition:transform .25s ease,box-shadow .3s ease!important}
.vf-card:hover,.vf-card-new:hover,[data-liveidx]:hover,.s-grid-card:hover {
  transform:translateY(-6px)!important;
  box-shadow:
    -4px 6px 20px rgba(var(--glow-r),var(--glow-g),var(--glow-b),.18),
    -8px 12px 50px rgba(var(--glow-r),var(--glow-g),var(--glow-b),.12),
    -12px 20px 80px rgba(var(--glow-r2),var(--glow-g2),var(--glow-b2),.08)!important
}
/* ── Thumbnails: sharp corners ── */
.vf-card-thumb,.vf-card-new .vf-card-thumb,.vf-upnext-thumb,
.s-grid-card img,[data-liveidx] img {
  border-radius:0!important;border:none!important
}
.vf-card-thumb img,.vf-card-thumb video{border-radius:0!important}
/* ── NO gradient overlay on thumbnails ── */
.vf-card-thumb::after{display:none!important}
/* ── Card body: BELOW thumbnail, not overlaid ── */
.vf-card-body,.vf-card-info{
  position:relative!important;bottom:auto!important;left:auto!important;right:auto!important;
  z-index:auto!important;padding:10px 0 16px!important;background:transparent!important
}
/* ── Card title: inherit color from theme, not white ── */
.vf-card-title{color:var(--tx)!important;font-size:14px!important;font-weight:600!important;
  text-shadow:none!important;letter-spacing:-.01em;line-height:1.4!important}
.vf-card-title-new{color:var(--tx)!important;font-size:14px!important;font-weight:600!important;text-shadow:none!important}
/* ── Card meta: theme-aware ── */
.vf-card-meta,.vf-card-meta-new{color:var(--tx3)!important}
.vf-card-stats{color:var(--tx3)!important}
/* ── Creator avatar: hidden — clean card look ── */
.vf-card-creator-avatar,.vf-card-avatar{display:none!important}
/* ── Card body: block layout, title + meta as one unit ── */
.vf-card-body,.vf-card-info{
  position:relative!important;bottom:auto!important;left:auto!important;right:auto!important;
  z-index:auto!important;padding:10px 2px 4px!important;background:transparent!important;display:block!important
}
.vf-card-title,.vf-card-title-new{color:var(--tx)!important;text-shadow:none!important;font-size:14px!important;font-weight:600!important}
.vf-card-meta,.vf-card-meta-new{color:var(--tx3)!important;font-size:12px!important}
/* ── Duration badge: bottom-right on thumbnail ── */
.vf-card-duration{bottom:8px!important;right:8px!important;top:auto!important;border-radius:4px!important;font-size:12px!important;z-index:2}
.vf-card-type{top:8px!important;left:8px!important;z-index:2}
/* ── Grid: responsive columns like YouTube ── */
.vf-grid{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))!important;gap:16px 16px!important;margin-bottom:24px!important}

/* ── Seeds: clean separators ── */
#seedCompose,#seedsFeed > div {
  border:none!important;box-shadow:none!important;border-radius:0!important;
  background:transparent!important;padding:14px 0!important;
  border-bottom:1px solid rgba(128,128,128,.08)!important
}
/* ── Music: clean rows ── */
.suno-track{border:none!important;border-radius:0!important;background:transparent!important;
  border-bottom:1px solid rgba(128,128,128,.06)!important;padding:10px 0!important}
.suno-track:hover{background:rgba(128,128,128,.04)!important}
/* ── Live cards ── */
[data-liveidx]{background:transparent!important;border:none!important;padding:8px!important;border-radius:12px!important}
/* ── Discover cards: subtle ── */
.vf-discover-card{border:none!important;border-radius:12px!important}
/* ── Up Next: YouTube-style horizontal shelf ── */
/* Up Next sidebar — YouTube-style vertical list */
.vf-yt-sidebar::-webkit-scrollbar{display:none}
.vf-yt-sidebar .vf-upnext-card,.vf-upnext-card{width:100%!important;border:none!important;background:transparent!important;border-radius:0!important;display:flex!important;gap:8px!important;align-items:flex-start!important}
.vf-yt-sidebar .vf-upnext-thumb,.vf-upnext-thumb{width:168px!important;height:94px!important;border-radius:6px!important;flex-shrink:0!important}
.vf-yt-sidebar .vf-upnext-title{font-size:12px!important;font-weight:600!important;margin-top:0!important;line-height:1.3}
.vf-yt-sidebar .vf-upnext-creator{font-size:10px!important;color:var(--tx3)!important}
.vf-upnext-title{font-size:12px!important;font-weight:500!important;color:var(--tx)!important;margin-top:8px!important;line-height:1.3!important}
.vf-upnext-row{padding:8px 0!important;gap:8px}
/* ── Queue items ── */
.vq-item{border-radius:8px!important;border:none!important}
[data-cwqid]{border-radius:8px!important;border:none!important}
/* ── Stats: clean numbers ── */
.vf-stat-tile{background:transparent!important;border:none!important;box-shadow:none!important;padding:12px 0!important}
/* ── Featured banner: full bleed, subtle radius ── */
.vf-featured{min-height:300px!important;border-radius:0!important;margin:0 -32px!important;width:calc(100% + 64px)!important}
.vf-featured h2{font-size:28px!important;font-weight:900!important}

/* ═══════════════════════════════════════════════════════════════
   DARK FLAT OVERRIDES — All 4 content tabs
   Match the Videos tab dark aesthetic
   ═══════════════════════════════════════════════════════════════ */

/* ── GLOBAL: tab content dark overrides ── */
.vf-main > div > div{color:var(--tx)}
.vf-main [style*="border:1px solid var(--border)"]{border-color:rgba(255,255,255,.06)!important}

/* ── 1. SEEDS TAB — Twitter/X dark feed ── */
#seedCompose textarea,#seedCompose input[type="text"]{
  background:rgba(255,255,255,.06)!important;border:1px solid rgba(255,255,255,.08)!important;
  color:#fff!important;border-radius:12px!important
}
#seedsFeed > div{
  background:transparent!important;border:none!important;
  border-bottom:1px solid rgba(255,255,255,.06)!important;padding:16px 0!important
}
#seedsFeed button{background:none!important;border:none!important;color:rgba(255,255,255,.4)!important;transition:color .15s!important}
#seedsFeed button:hover{color:#fff!important}
#seedsFeed img[style*="border-radius:50%"]{border-radius:50%!important}
#seedCompose [style*="border-top:1px"]{border-top-color:rgba(255,255,255,.06)!important}
#seedsFeed [style*="border-top:1px"]{border-top-color:rgba(255,255,255,.06)!important}

/* ── 2. LIVE TAB — Twitch-style dark grid ── */
/* Live category pills — match Videos filter chips */
#liveCatFilter .s-cat-pill{
  background:rgba(255,255,255,.1)!important;border:none!important;color:var(--tx2)!important;
  padding:6px 14px!important;font-size:13px!important;font-weight:500!important;border-radius:8px!important
}
#liveCatFilter .s-cat-pill.active{background:#fff!important;color:#000!important;font-weight:600!important}
#liveCatFilter .s-cat-pill:hover:not(.active){background:rgba(255,255,255,.18)!important;color:var(--tx)!important}
/* Live viewer badge: prominent white on dark */
[data-liveidx] .vf-card-duration,[data-liveidx] [style*="background:rgba(0,0,0"]{
  background:rgba(0,0,0,.7)!important;color:#fff!important;font-weight:700!important;backdrop-filter:blur(4px)!important
}

/* ── 3. MUSIC TAB — Suno-style dark ── */
#musicHeroLayout,#vizHero{background:#0A0A0F!important;border:none!important}
#lyricsDisplay::-webkit-scrollbar{display:none}
#lyricsDisplay{scrollbar-width:none}
#lyricsContent{animation:lyricsFade .5s ease}
@keyframes lyricsFade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.suno-track{border-bottom:1px solid rgba(255,255,255,.04)!important}
.suno-track:hover{background:rgba(255,255,255,.03)!important}

/* ── 4. PODCAST TAB — Spotify-style dark player ── */
#podcastPlayer{background:rgba(255,255,255,.04)!important;border:none!important;border-radius:0!important}
#podcastHeader{background:linear-gradient(135deg,rgba(212,175,55,.06),rgba(12,155,141,.03))!important}
#podcastChapters [style*="border-bottom"]{border-bottom-color:rgba(255,255,255,.06)!important}
#podcastChapters > div[onclick]:hover{background:rgba(255,255,255,.04)!important}
#gtVoiceSelect,#podcastChapters select{
  background:rgba(255,255,255,.06)!important;border:1px solid rgba(255,255,255,.08)!important;
  color:#fff!important;border-radius:8px!important
}
#podcastAudio{background:rgba(255,255,255,.02)!important}
#podcastAudio audio{width:100%;filter:invert(1) hue-rotate(180deg);opacity:.85}
#podcastText{color:rgba(255,255,255,.6)!important}
/* Golden Thread section — cinematic */
#podcastChapters .vf-section-hdr .vf-section-title{font-size:20px!important;font-weight:900!important}
#podcastChapters [style*="border-radius:50%"]{
  background:rgba(212,175,55,.12)!important;color:var(--gold,#C8A23C)!important
}
/* Podcast buttons */
.vf-btn-outline{background:rgba(255,255,255,.06)!important;border:1px solid rgba(255,255,255,.1)!important;color:#fff!important}
.vf-btn-outline:hover{background:rgba(255,255,255,.1)!important}

/* ── Header: synced with Hero Player shadow glow ── */
.vf-header{
  background:rgba(10,10,15,.88)!important;
  border-bottom:none!important;
  backdrop-filter:blur(16px)!important;
  -webkit-backdrop-filter:blur(16px)!important;
  box-shadow:
    0 1px 0 rgba(var(--glow-r),var(--glow-g),var(--glow-b),.08),
    0 4px 20px rgba(var(--glow-r),var(--glow-g),var(--glow-b),.06),
    0 8px 40px rgba(var(--glow-r2),var(--glow-g2),var(--glow-b2),.04)!important;
  transition:box-shadow .3s ease,transform .3s ease,opacity .3s ease!important
}
/* ── Search: glow-synced focus ring ── */
.vf-search input{background:rgba(255,255,255,.06)!important;border:1px solid rgba(255,255,255,.08)!important;color:#fff!important;border-radius:20px!important;font-size:13px!important;padding:8px 16px 8px 36px!important;transition:border-color .2s,box-shadow .3s!important}
.vf-search input::placeholder{color:rgba(255,255,255,.3)!important}
.vf-search input:focus{
  border-color:rgba(var(--glow-r),var(--glow-g),var(--glow-b),.4)!important;
  box-shadow:0 0 0 3px rgba(var(--glow-r),var(--glow-g),var(--glow-b),.1),0 4px 16px rgba(var(--glow-r2),var(--glow-g2),var(--glow-b2),.08)!important;
  background:rgba(255,255,255,.04)!important
}

/* ── Section headers ── */
.vf-section-hdr{margin-top:28px!important;margin-bottom:12px!important}
.vf-section-hdr span:first-child{font-size:18px!important;font-weight:700!important}
/* ── Filter chips: YouTube pill style ── */
@media(min-width:769px){
  .vf-filter-chips{gap:8px!important;padding:12px 0!important;border-bottom:none!important}
  .vf-filter-chip{background:rgba(255,255,255,.1)!important;border:none!important;color:var(--tx2)!important;padding:6px 14px!important;font-size:13px!important;font-weight:500!important;border-radius:8px!important;transition:all .15s!important}
  .vf-filter-chip.active{background:#fff!important;color:#000!important;font-weight:600!important}
  .vf-filter-chip:hover{background:rgba(255,255,255,.18)!important;color:var(--tx)!important}
}

/* ── Mobile: YouTube mobile grid ── */
@media(max-width:768px){
  .vf-grid{grid-template-columns:1fr!important;gap:12px!important}
  .vf-card,.vf-card-new{margin-bottom:0!important}
  .vf-card-thumb,.vf-card-new .vf-card-thumb{border-radius:0!important;aspect-ratio:16/9!important}
  .vf-card-body,.vf-card-info{padding:10px 14px 8px!important;display:block!important}
  .vf-card-creator-avatar,.vf-card-avatar{display:none!important}
  .vf-featured{margin:0!important;width:100%!important;border-radius:0!important}
  .vf-bottom-tabs{
    background:rgba(10,10,15,.9)!important;border-top:none!important;
    backdrop-filter:blur(16px)!important;-webkit-backdrop-filter:blur(16px)!important;
    box-shadow:0 -1px 0 rgba(var(--glow-r),var(--glow-g),var(--glow-b),.06),0 -4px 20px rgba(var(--glow-r2),var(--glow-g2),var(--glow-b2),.04)!important;
    transition:box-shadow .3s ease!important
  }
  .vf-bottom-tab{color:rgba(255,255,255,.5)!important}
  .vf-bottom-tab.active{color:#fff!important}
}
@media(max-width:480px){
  .vf-card-title{font-size:13px!important}
  .vf-verified{width:14px!important;height:14px!important;font-size:8px!important;margin-right:3px!important}
  .vf-card-creator-avatar,.vf-card-avatar{display:none!important}
}

/* ═══ CARD GRID ═══ */
.vf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-bottom:24px}
.vf-card{background:transparent;border:none;box-shadow:none;border-radius:0;overflow:visible;cursor:pointer;position:relative;transition:transform .25s ease,box-shadow .3s ease}
.vf-card:hover{transform:translateY(-6px);box-shadow:-4px 6px 20px rgba(var(--glow-r),var(--glow-g),var(--glow-b),.18),-8px 12px 50px rgba(var(--glow-r),var(--glow-g),var(--glow-b),.12),-12px 20px 80px rgba(var(--glow-r2),var(--glow-g2),var(--glow-b2),.08)}
.vf-card-thumb{width:100%;aspect-ratio:16/9;border-radius:0;position:relative;overflow:hidden;background:var(--bg3)}
.vf-card-thumb img,.vf-card-thumb video{width:100%;height:100%;object-fit:cover;border-radius:0}
.vf-card-thumb .vf-play-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:48px;height:48px;background:rgba(0,0,0,.6);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;color:#fff;opacity:0;transition:opacity .2s}
.vf-card:hover .vf-play-icon{opacity:1}
.vf-card:hover .vf-pl-add{opacity:1!important}
.vf-pl-dropdown{position:absolute;bottom:36px;right:8px;background:var(--bg2);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:4px 0;z-index:20;min-width:140px;box-shadow:0 4px 16px rgba(0,0,0,.5);max-height:180px;overflow-y:auto}
.vf-pl-dropdown div{padding:6px 12px;font-size:11px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vf-pl-dropdown div:hover{background:rgba(255,255,255,.06)}
.vf-card-duration{position:absolute;bottom:8px;right:8px;background:rgba(0,0,0,.8);color:#fff;padding:2px 6px;border-radius:4px;font-size:12px;font-family:var(--mono);font-weight:600;z-index:2}
.vf-card-type{position:absolute;top:8px;left:8px;padding:3px 8px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;z-index:2}
.vf-card-type.video{background:rgba(45,101,217,.9);color:#fff}
.vf-card-type.audio{background:rgba(110,66,201,.9);color:#fff}
.vf-card-type.live{background:var(--red);color:#fff;animation:pulse-live 2s infinite}
.vf-card-type.p2p{background:rgba(12,155,141,.9);color:#fff}
@keyframes pulse-live{0%,100%{opacity:1}50%{opacity:.6}}
.vf-card-body{padding:10px 2px 4px;background:transparent;display:block}
.vf-card-title{font-size:14px;font-weight:600;color:var(--tx);margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4}
.vf-card-meta{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--tx3);margin-top:2px}
.vf-card-creator{display:flex;align-items:center;gap:5px}
.vf-card-creator-avatar{display:none}
.vf-card-stats{margin-left:auto;display:flex;gap:10px;font-size:11px;color:var(--tx3)}

/* ═══ FEATURED BANNER ═══ */
.vf-featured{margin-bottom:32px;border-radius:var(--r);overflow:hidden;background:#000;position:relative;min-height:280px;display:flex;align-items:flex-end}
.vf-featured-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;opacity:.5;transition:opacity .4s}
.vf-featured::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.3) 50%,transparent 100%)}
.vf-featured-content{position:relative;z-index:2;padding:32px;width:100%}
.vf-featured h2{font-size:28px;font-weight:900;letter-spacing:-.03em;margin-bottom:4px;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.vf-featured-sub{font-size:13px;color:rgba(255,255,255,.6);margin-bottom:6px}
.vf-featured p{color:rgba(255,255,255,.7);font-size:14px;max-width:500px;line-height:1.5;margin-bottom:16px}
.vf-featured-badges{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.vf-featured-badge{padding:4px 12px;border-radius:20px;font-size:11px;font-weight:800;letter-spacing:.5px}
.vf-featured-badge.gold{background:linear-gradient(135deg,#FFD700,#FF8C00);color:#000}
.vf-featured-badge.green{background:#4CAF50;color:#fff}
.vf-featured-badge.dark{background:rgba(255,255,255,.1);color:rgba(255,255,255,.7)}
.vf-featured-btns{display:flex;gap:10px;flex-wrap:wrap}
.vf-featured-btn{padding:12px 24px;border-radius:50px;border:none;font-family:var(--font);font-weight:800;font-size:14px;cursor:pointer;transition:transform .15s;text-decoration:none;display:inline-flex;align-items:center;gap:8px}
.vf-featured-btn:hover{transform:scale(1.04)}
.vf-featured-btn.primary{background:linear-gradient(135deg,#FFD700,#FF8C00);color:#000}
.vf-featured-btn.outline{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.25);backdrop-filter:blur(4px)}

/* ═══ UPLOAD / STUDIO ═══ */
.vf-upload-area{border:2px dashed var(--border);border-radius:var(--r);padding:36px;text-align:center;cursor:pointer;transition:all .2s;margin-bottom:20px;background:var(--card)}
.vf-upload-area:hover{border-color:var(--accent);background:var(--accent-l)}
.vf-upload-icon{font-size:40px;margin-bottom:10px;opacity:.4}
.vf-upload-text{font-size:14px;font-weight:600;color:var(--tx);margin-bottom:4px}
.vf-upload-sub{font-size:12px;color:var(--tx3)}

/* ═══ CREATOR CARD ═══ */
.vf-creator-card{background:var(--card);border-radius:var(--r);border:1px solid var(--border);padding:20px;text-align:center;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s}
.vf-creator-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.vf-creator-avatar{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,var(--accent),var(--accent-d));color:#fff;margin:0 auto 10px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;overflow:hidden}
.vf-creator-avatar img{width:100%;height:100%;object-fit:cover}
.vf-creator-name{font-weight:700;font-size:14px;margin-bottom:3px}
.vf-creator-handle{font-size:12px;color:var(--tx3);margin-bottom:10px}
.vf-creator-stats{display:flex;justify-content:center;gap:20px;font-size:12px;color:var(--tx2)}
.vf-creator-stat-num{font-weight:800;font-size:16px;color:var(--tx);display:block;font-family:var(--mono)}

/* ═══ PLAYER OVERLAY ═══ */
.vf-player-overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.92);display:none;flex-direction:column;align-items:center;justify-content:center;backdrop-filter:blur(8px)}
.vf-player-overlay.show{display:flex}
.vf-player-close{position:absolute;top:16px;right:20px;font-size:28px;color:#fff;cursor:pointer;z-index:10;opacity:.7;transition:opacity .15s}
.vf-player-close:hover{opacity:1}
.vf-player-video{max-width:90%;max-height:70vh;border-radius:var(--r);background:#000}
.vf-player-info{padding:20px;max-width:600px;text-align:center}
.vf-player-title{font-size:18px;font-weight:700;margin-bottom:8px;color:#fff}
.vf-player-actions{display:flex;gap:10px;justify-content:center;margin-top:16px}

/* ═══ PAYWALL OVERLAY ═══ */
.vf-paywall{position:absolute;inset:0;z-index:15;display:none;flex-direction:column;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,rgba(0,0,0,.7) 0%,rgba(0,0,0,.95) 100%);backdrop-filter:blur(12px);transition:opacity .4s}
.vf-paywall.show{display:flex}
.vf-paywall-glass{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:32px 28px;max-width:380px;width:90%;text-align:center;backdrop-filter:blur(20px);box-shadow:0 8px 40px rgba(0,0,0,.5)}
.vf-paywall-icon{font-size:48px;margin-bottom:12px;animation:vfPwPulse 2s infinite}
@keyframes vfPwPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}
.vf-paywall-title{font-size:20px;font-weight:800;color:#fff;margin-bottom:6px;letter-spacing:-.3px}
.vf-paywall-sub{font-size:13px;color:rgba(255,255,255,.55);margin-bottom:20px;line-height:1.4}
.vf-paywall-price{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#FFD700,#FF8C00);color:#000;font-size:22px;font-weight:800;padding:14px 32px;border-radius:50px;cursor:pointer;border:none;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 20px rgba(255,215,0,.3)}
.vf-paywall-price:hover{transform:scale(1.05);box-shadow:0 6px 30px rgba(255,215,0,.5)}
.vf-paywall-price:active{transform:scale(.97)}
.vf-paywall-price.loading{opacity:.6;pointer-events:none}
.vf-paywall-balance{font-size:12px;color:rgba(255,255,255,.6);margin-top:12px}
.vf-paywall-preview-bar{position:absolute;bottom:0;left:0;width:100%;height:4px;background:rgba(255,255,255,.1)}
.vf-paywall-preview-fill{height:100%;background:linear-gradient(90deg,#FFD700,#FF4500);transition:width .3s;border-radius:0 2px 2px 0}
.vf-paywall-countdown{display:inline-block;background:rgba(255,0,0,.7);color:#fff;font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;position:absolute;top:16px;left:16px;z-index:16}
.vf-paywall-success{display:none;flex-direction:column;align-items:center;gap:12px}
.vf-paywall-success.show{display:flex}
.vf-paywall-success-icon{font-size:64px;animation:vfPwUnlock .6s ease-out}
@keyframes vfPwUnlock{0%{transform:scale(0) rotate(-20deg);opacity:0}50%{transform:scale(1.2) rotate(5deg)}100%{transform:scale(1) rotate(0);opacity:1}}
.vf-paywall-success-text{font-size:18px;font-weight:700;color:#FFD700}
.vf-paywall-login{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.2);font-size:14px;font-weight:600;padding:12px 28px;border-radius:50px;cursor:pointer;margin-top:8px;transition:background .15s}
.vf-paywall-login:hover{background:rgba(255,255,255,.2)}
.vf-paywall-divider{display:flex;align-items:center;gap:12px;margin:16px 0 12px;color:rgba(255,255,255,.5);font-size:12px;text-transform:uppercase;letter-spacing:1px}
.vf-paywall-divider::before,.vf-paywall-divider::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.12)}
.vf-paywall-stripe{display:inline-flex;align-items:center;gap:8px;background:#fff;color:#1a1a2e;font-size:15px;font-weight:700;padding:13px 28px;border-radius:50px;cursor:pointer;border:none;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 20px rgba(0,0,0,.2);width:100%;justify-content:center}
.vf-paywall-stripe:hover{transform:scale(1.03);box-shadow:0 6px 30px rgba(0,0,0,.3)}
.vf-paywall-stripe:active{transform:scale(.97)}
.vf-paywall-stripe.loading{opacity:.6;pointer-events:none}
.vf-card-exclusive{position:absolute;top:8px;left:8px;background:linear-gradient(135deg,#FFD700,#FF8C00);color:#000;font-size:10px;font-weight:800;padding:3px 8px;border-radius:10px;letter-spacing:.5px;z-index:2}
.vf-card-price{position:absolute;bottom:8px;right:8px;background:rgba(0,0,0,.75);color:#FFD700;font-size:11px;font-weight:700;padding:3px 8px;border-radius:10px;z-index:2}

/* ═══ MUSIC TRACKS ═══ */
.vf-track{display:flex;align-items:center;gap:12px;padding:11px 16px;border-bottom:1px solid var(--border);transition:background .15s;cursor:pointer}
.vf-track:hover{background:var(--accent-l)}
.vf-track:last-child{border-bottom:none}
.vf-track.playing{background:var(--accent-l)}
.vf-track-num{width:22px;font-size:12px;color:var(--txl);font-family:var(--mono);text-align:center;flex-shrink:0}
.vf-track.playing .vf-track-num{color:var(--accent)}
.vf-track-art{width:40px;height:40px;border-radius:8px;background:var(--bg3);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--txl);overflow:hidden}
.vf-track-art img{width:100%;height:100%;object-fit:cover}
.vf-track-info{flex:1;min-width:0}
.vf-track-title{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vf-track.playing .vf-track-title{color:var(--accent)}
.vf-track-artist{font-size:11px;color:var(--tx3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vf-track-dur{font-size:11px;color:var(--txl);font-family:var(--mono);flex-shrink:0}
.vf-online{width:6px;height:6px;border-radius:50%;display:inline-block;margin-right:3px}
.vf-online.on{background:var(--green)}.vf-online.off{background:var(--txl)}

/* ═══ MUSIC PLAYER BAR ═══ */
.vf-music-bar{position:fixed;bottom:0;left:0;right:0;z-index:150;background:rgba(10,10,15,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.06);padding:0 20px;height:72px;display:none;align-items:center;gap:12px}
.vf-music-bar.show{display:flex}
.vf-music-bar-art{width:44px;height:44px;border-radius:8px;background:var(--bg3);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--txl);overflow:hidden}
.vf-music-bar-art img{width:100%;height:100%;object-fit:cover}
.vf-music-bar-info{min-width:0;max-width:180px;flex-shrink:0}
.vf-music-bar-title{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vf-music-bar-artist{font-size:10px;color:var(--tx3)}
.vf-music-bar-controls{display:flex;align-items:center;gap:8px}
.vf-music-bar-btn{width:32px;height:32px;border-radius:50%;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;color:rgba(255,255,255,.5);transition:all .15s}
.vf-music-bar-btn:hover{color:#fff}
.vf-music-bar-play{background:#fff;color:#000;width:36px;height:36px;font-size:15px;border:none}
.vf-music-bar-play:hover{transform:scale(1.08)}
.vf-music-bar-progress{flex:1;max-width:500px;display:flex;align-items:center;gap:6px}
.vf-music-bar-time{font-size:10px;font-family:var(--mono);color:rgba(255,255,255,.3);min-width:34px;text-align:center}
.vf-music-bar-slider{flex:1;height:22px;background:transparent;cursor:pointer;position:relative;display:flex;align-items:center}
.vf-music-bar-slider .vf-bar-track{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);height:4px;background:rgba(255,255,255,.1);border-radius:2px}
.vf-music-bar-fill{height:4px;background:var(--accent,#0C9B8D);border-radius:2px;width:0%;transition:width .05s linear;position:absolute;left:0;top:50%;transform:translateY(-50%);z-index:1}
.vf-music-bar-thumb{position:absolute;width:14px;height:14px;border-radius:50%;background:#fff;box-shadow:0 0 4px rgba(0,0,0,.4);z-index:2;top:50%;transform:translate(-50%,-50%);left:0%;opacity:0;transition:opacity .15s}
.vf-music-bar-slider:hover .vf-music-bar-thumb,.vf-music-bar-slider:active .vf-music-bar-thumb,.vf-music-bar-slider.scrubbing .vf-music-bar-thumb{opacity:1}
.vf-music-bar-slider:hover .vf-bar-track,.vf-music-bar-slider:hover .vf-music-bar-fill{height:6px}
.vf-music-bar-close{color:rgba(255,255,255,.3);cursor:pointer;font-size:16px;padding:4px;transition:color .15s}
.vf-music-bar-close:hover{color:#fff}
/* Music tab timeline */
#musicTimelineSlider:hover #musicTimelineThumb{opacity:1}
#musicTimelineSlider:hover div[style*="height:4px"]{height:6px!important}

/* ═══ MUSIC GRID CARDS ═══ */
.vf-music-card{background:var(--card);border-radius:var(--r);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;cursor:pointer}
.vf-music-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.vf-music-card-art{width:100%;aspect-ratio:1;background:linear-gradient(135deg,var(--bg3),var(--bg4));display:flex;align-items:center;justify-content:center;font-size:40px;color:var(--txl);overflow:hidden;position:relative}
.vf-music-card-art img{width:100%;height:100%;object-fit:cover}
.vf-music-card-play{position:absolute;bottom:8px;right:8px;width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;opacity:0;transition:opacity .2s,transform .2s;transform:translateY(4px);box-shadow:0 4px 12px rgba(12,155,141,.3)}
.vf-music-card:hover .vf-music-card-play{opacity:1;transform:translateY(0)}
.vf-music-card-body{padding:10px 12px}
.vf-music-card-title{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vf-music-card-sub{font-size:11px;color:var(--tx3);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

body.music-playing .vf-main{padding-bottom:88px}

/* ═══ MUSIC CEED BADGES & TIPS ═══ */
.vf-music-card-stream-badge{position:absolute;top:6px;left:6px;background:rgba(0,0,0,.7);color:var(--gold,#C8A23C);font-size:8px;font-weight:800;padding:2px 5px;border-radius:4px;backdrop-filter:blur(4px);pointer-events:none}
.vf-music-card-price-badge{position:absolute;top:6px;right:6px;background:var(--gold,#C8A23C);color:#000;font-size:8px;font-weight:800;padding:2px 5px;border-radius:4px}
.vf-music-card-locked{position:absolute;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:4px;backdrop-filter:blur(2px)}
.vf-music-card-locked span{font-size:24px}
.vf-music-card-locked em{font-style:normal;font-size:10px;font-weight:700;color:var(--gold,#C8A23C)}
.vf-music-tip-btn{position:absolute;bottom:8px;left:8px;width:28px;height:28px;border-radius:50%;background:var(--gold,#C8A23C);color:#000;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;opacity:0;transition:opacity .2s,transform .2s;transform:translateY(4px);cursor:pointer;border:none;box-shadow:0 2px 8px rgba(200,162,60,.3)}
.vf-music-card:hover .vf-music-tip-btn{opacity:1;transform:translateY(0)}
.vf-music-queue-btn{position:absolute;top:24px;left:6px;width:24px;height:24px;border-radius:6px;background:rgba(0,0,0,.65);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;opacity:0;transition:opacity .2s;cursor:pointer;border:none;backdrop-filter:blur(4px)}
.vf-music-card:hover .vf-music-queue-btn{opacity:1}
.suno-track .suno-tip-btn{opacity:0;transition:opacity .15s;background:var(--gold,#C8A23C);color:#000;border:none;border-radius:6px;padding:2px 7px;font-size:9px;font-weight:800;cursor:pointer;flex-shrink:0;font-family:var(--font)}
.suno-track:hover .suno-tip-btn{opacity:1}
.suno-track .suno-queue-btn{opacity:0;transition:opacity .15s;background:rgba(255,255,255,.1);color:var(--tx2);border:none;border-radius:6px;padding:2px 6px;font-size:9px;font-weight:700;cursor:pointer;flex-shrink:0;font-family:var(--font)}
.suno-track:hover .suno-queue-btn{opacity:1}
.vf-user-queue-section{background:var(--card);border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--shadow);margin-bottom:24px;max-height:280px;overflow-y:auto}
.vf-user-queue-track{display:flex;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px solid var(--border);cursor:grab;transition:background .15s}
.vf-user-queue-track:hover{background:var(--bg2)}
.vf-user-queue-track:last-child{border-bottom:none}
.vf-user-queue-track.dragging{opacity:.4}
.vf-user-queue-track .uq-grip{color:var(--txl);font-size:12px;cursor:grab;flex-shrink:0;user-select:none}
.vf-user-queue-track .uq-art{width:36px;height:36px;border-radius:6px;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--txl);overflow:hidden;flex-shrink:0}
.vf-user-queue-track .uq-art img{width:100%;height:100%;object-fit:cover}
.vf-user-queue-track .uq-info{flex:1;min-width:0}
.vf-user-queue-track .uq-title{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vf-user-queue-track .uq-sub{font-size:10px;color:var(--tx3)}
.vf-user-queue-track .uq-rm{background:none;border:none;color:var(--txl);cursor:pointer;font-size:14px;padding:2px 4px;transition:color .15s;flex-shrink:0}
.vf-user-queue-track .uq-rm:hover{color:var(--accent)}
.music-tip-inline{display:inline-flex;align-items:center;gap:4px;background:var(--card);border:1px solid var(--gold,#C8A23C);border-radius:8px;padding:4px 8px;font-size:11px;font-weight:700;white-space:nowrap}
.music-tip-inline button{border:none;border-radius:6px;padding:3px 10px;font-size:10px;font-weight:800;cursor:pointer;font-family:var(--font)}
.music-tip-inline .mti-send{background:var(--gold,#C8A23C);color:#000}
.music-tip-inline .mti-cancel{background:var(--bg3);color:var(--tx2)}

/* ═══ TIP MODAL ═══ */
.vf-modal{position:fixed;inset:0;z-index:300;background:var(--overlay);display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.vf-modal.show{display:flex}
.vf-modal-box{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:28px;width:90%;max-width:420px;box-shadow:var(--shadow-lg)}
.vf-modal-title{font-size:16px;font-weight:700;margin-bottom:16px;display:flex;justify-content:space-between;align-items:center}
.vf-modal-close{cursor:pointer;font-size:18px;color:var(--tx3);transition:color .15s}
.vf-modal-close:hover{color:var(--tx)}
.vf-tip-amounts{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}
.vf-tip-amount{padding:10px;text-align:center;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);cursor:pointer;font-weight:700;font-size:14px;transition:all .15s;font-family:var(--mono);color:var(--tx)}
.vf-tip-amount:hover,.vf-tip-amount.selected{border-color:var(--gold);background:var(--gold-l);color:var(--gold)}
.vf-input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-btn);padding:11px 14px;color:var(--tx);font-family:var(--font);font-size:14px;outline:none;margin-bottom:12px;transition:border .15s}
.vf-input:focus{border-color:var(--accent)}

/* ═══ STATS ═══ */
.vf-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:24px}
.vf-stat-tile{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:18px;box-shadow:var(--shadow);text-align:center}
.vf-stat-value{font-size:22px;font-weight:900;font-family:var(--mono);color:var(--accent)}
.vf-stat-label{font-size:10px;color:var(--tx3);margin-top:4px;text-transform:uppercase;letter-spacing:1px;font-weight:600}

/* ═══ TOAST ═══ */
.vf-toast{position:fixed;bottom:100px;right:24px;background:rgba(20,20,30,.9)!important;border:1px solid rgba(255,255,255,.08)!important;backdrop-filter:blur(12px)!important;border-radius:12px!important;padding:12px 20px;box-shadow:none;z-index:99999;transform:translateY(100px);opacity:0;transition:all .3s;font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px;max-width:calc(100vw - 48px)}
.vf-toast.show{transform:translateY(0);opacity:1}
.vf-toast.success{border-left:3px solid var(--green)}.vf-toast.error{border-left:3px solid var(--red)}
@media(max-width:600px){.vf-toast{bottom:80px;right:12px;left:12px;max-width:none}}

/* ═══ AUTH / EMPTY ═══ */
.vf-auth{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:40px}
.vf-auth h2{font-size:22px;font-weight:800;margin-bottom:8px;letter-spacing:-.02em}
.vf-auth p{color:var(--tx2);margin-bottom:24px;max-width:400px;line-height:1.5}
.vf-empty{text-align:center;padding:64px 24px;color:var(--tx3)}
.vf-empty-icon{font-size:48px;margin-bottom:12px;opacity:.3}
.vf-empty-text{font-size:14px}

/* ═══ RESPONSIVE ═══ */
@media(max-width:768px){
  /* Slim top bar — no tabs */
  .vf-header{padding:0 12px;height:40px;flex-wrap:nowrap;gap:8px}
  .vf-header-nav{display:none!important}
  .vf-main{margin-top:40px;padding:0;scroll-margin-top:40px;padding-bottom:64px}
  /* Bottom tab bar */
  .vf-bottom-tabs{display:flex!important}
  .vf-bottom-tabs.hidden{transform:translateY(100%)}
  .vf-bottom-tabs.immersive-hidden{display:none!important}
  .vf-header.immersive-hidden{display:none!important}
  /* Immersive mode — kill the entire old layout */
  body.immersive .vf-header{display:none!important}
  body.immersive .vf-bottom-tabs{display:none!important}
  body.immersive .vf-main{margin-top:0!important;padding:0!important;max-width:none!important;padding-bottom:0!important;transition:none!important;overflow:hidden!important;height:0!important;min-height:0!important}
  body.immersive .vf-music-bar{display:none!important}
  body.immersive .vf-toast{display:none!important}
  body.immersive .vf-conn-banner{display:none!important}
  body.immersive .vf-go-live-fab{display:none!important}
  body.immersive #goLiveFloatBtn{display:none!important}
  body.immersive #ceed-agent-fab{display:none!important}
  body.immersive #podFab{display:none!important}
  .vf-search{max-width:none;flex:1}
  .vf-search input{font-size:12px;padding:7px 12px 7px 32px}
  .vf-grid{display:flex;flex-direction:column;gap:0}
  .vf-featured h2{font-size:20px}
  .vf-featured{min-height:220px}
  .vf-stats{grid-template-columns:repeat(2,1fr)}
  .vf-music-bar-progress{max-width:100%;margin-top:2px}
  /* Hero player — edge-to-edge, immersive mobile */
  .hp-viz{border-radius:0}
  .hp-viz::before{border-radius:0}
  #videoHeroLayout{margin-left:0!important;margin-right:0!important;margin-bottom:0!important;width:100%!important}
  /* Shadow glow — tighter on mobile */
  #vidHeroViz{--hp-glow-spread:20px}
  /* Cinema mode on mobile — hide header + bottom tabs */
  .vf-header.cinema-mobile{transform:translateY(-100%)!important;transition:transform .3s ease!important}
  .vf-bottom-tabs.cinema-mobile{transform:translateY(100%)!important;transition:transform .3s ease!important}
  /* When cinema is active, hero occupies freed space */
  .vf-main.cinema-mobile{margin-top:0!important;transition:margin-top .3s ease!important}
  /* Video cards — edge-to-edge on mobile */
  .vf-card-new .vf-card-thumb{border-radius:0;aspect-ratio:16/9!important}
  .vf-card-new{margin:0 0 2px}
  .vf-card-info{padding:14px 16px}
  /* Hero info — stack vertically on mobile */
  .vf-hero-info{padding:8px 12px}
  .vf-hero-info .vf-hero-top{flex-direction:column;align-items:flex-start;gap:4px}
  .vf-hero-info .vf-hero-title{font-size:14px}
  .vf-hero-info .vf-hero-actions{flex-direction:column;align-items:stretch;gap:8px}
  .vf-hero-info .vf-hero-action-btns{display:flex;gap:6px;justify-content:flex-start}
  /* Action buttons — icon-only on mobile */
  .vf-hero-action-btn .vf-btn-label{display:none}
  .vf-hero-action-btn{padding:8px 12px;min-width:40px;justify-content:center}
  /* Up Next — smaller cards */
  .vf-upnext-card{width:140px}
  .vf-upnext-thumb{width:140px;height:79px}
  .vf-upnext-title{font-size:10px}
  .vf-upnext-row{padding:8px 12px 12px}
  /* Timeline panel — stack vertically on mobile */
  .vf-timeline-panel{flex-direction:column!important;border-radius:12px!important;margin:8px 12px!important}
  .vf-timeline-panel .vf-filter-bar{width:100%!important;flex-direction:row!important;overflow-x:auto!important;border-right:none!important;border-bottom:1px solid rgba(255,255,255,.06)!important;padding:8px 12px!important;gap:8px!important;-webkit-overflow-scrolling:touch;flex-shrink:0!important}
  .vf-timeline-panel .vf-filter-bar .vf-filter-chip{white-space:nowrap!important;flex-shrink:0!important;width:auto!important;border-bottom:none!important;border-left:none!important;padding:6px 14px!important;border-radius:20px!important}
  .vf-timeline-panel .vf-filter-bar .vf-filter-chip.active{border-left:none!important}
  /* Override global .vf-grid mobile styles inside timeline */
  .vf-timeline-panel .vf-grid{display:flex!important;flex-direction:row!important;flex-wrap:wrap!important;overflow-x:visible!important;gap:8px!important;padding:8px!important}
  .vf-timeline-panel .vf-grid .vf-card,.vf-timeline-panel .vf-grid .vf-card-new{width:calc(50% - 4px)!important;min-width:calc(50% - 4px)!important;max-width:calc(50% - 4px)!important;flex-shrink:0!important;margin-bottom:0!important}
  .vf-timeline-panel .vf-grid .vf-card-thumb,.vf-timeline-panel .vf-grid .vf-card-new .vf-card-thumb{border-radius:8px!important;aspect-ratio:16/9!important}
  .vf-timeline-panel .vf-grid .vf-card-info,.vf-timeline-panel .vf-grid .vf-card-body{padding:6px 4px!important}
  /* Sports/Movies grids inside timeline — horizontal scroll on mobile */
  .vf-timeline-panel #sportsGrid,.vf-timeline-panel #mvGrid{display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;overflow-x:auto!important;gap:8px!important;padding:8px!important;-webkit-overflow-scrolling:touch!important;scrollbar-width:none!important}
  .vf-timeline-panel #sportsGrid::-webkit-scrollbar,.vf-timeline-panel #mvGrid::-webkit-scrollbar{display:none}
  /* Hero needs to clear the fixed chips bar (header 40px is handled by .vf-main margin-top, chips bar is ~34px) */
  /* Mobile: stack hero + sidebar vertically */
  #videoHeroLayout{padding-top:25px !important;scroll-margin-top:74px !important;flex-direction:column !important;padding:25px 0 0 0 !important;margin:0 !important;width:100% !important}
  .vf-yt-sidebar{width:100% !important;max-height:none !important;overflow:visible !important}
  .vf-yt-sidebar #vfUpNextRow{flex-direction:row !important;overflow-x:auto !important;gap:8px !important;-webkit-overflow-scrolling:touch}
  .vf-yt-sidebar .vf-upnext-card{width:140px !important;flex-shrink:0 !important;display:block !important}
  .vf-yt-sidebar .vf-upnext-thumb{width:140px !important;height:79px !important}
  .vf-filter-chips{padding:8px 12px}
  .vf-filter-chip{padding:6px 14px;font-size:11px;font-weight:600}
  /* Sports: stack player + list vertically */
  #sPlay{min-width:100% !important}
  #sList{width:100% !important;min-width:0 !important;max-height:40vh !important}
  #sCats{overflow-x:auto;flex-wrap:nowrap !important;-webkit-overflow-scrolling:touch}
  #sCats button{white-space:nowrap;flex-shrink:0}
  /* Movies: stack vertically on mobile, no sticky */
  #mvList{width:100% !important;min-width:0 !important;max-height:50vh !important;position:static !important;top:auto !important}
  #mvCats{overflow-x:auto;flex-wrap:nowrap !important;-webkit-overflow-scrolling:touch}
  #mvCats button{white-space:nowrap;flex-shrink:0}
  /* Movies mini-player: full width bottom bar on mobile */
  #moviePersist[style*="fixed"]{width:100% !important;right:0 !important;left:0 !important;bottom:0 !important;border-radius:12px 12px 0 0 !important}
  #sportsPersist[style*="fixed"]{width:100% !important;right:0 !important;left:0 !important;bottom:0 !important;border-radius:12px 12px 0 0 !important}
  /* Bet panel */
  .bet-panel{font-size:10px !important}
  /* Comments */
  .vf-comments{padding:0 12px}
  /* Section headers — add horizontal padding */
  .vf-section-hdr{padding-left:12px;padding-right:12px}
  /* Continue Watching */
  #vfContinueWatching{padding:0 12px}
  /* Playlists */
  #createPlaylistForm{margin-left:12px;margin-right:12px}
  #playlistsContainer{padding:0 12px}
  /* Sports/Movies grids */
  #sportsGrid{padding-left:12px}
  #mvCats{padding-left:12px}
  #mvGrid{padding:0 12px}
  /* Safe area for iOS notch */
  body{padding-bottom:env(safe-area-inset-bottom)}

  /* ══ Mobile: TIP Bottom Sheet — clean dark glass ══ */
  .hp-tip-slider{
    position:fixed !important;
    bottom:0 !important;left:0 !important;right:0 !important;top:auto !important;
    width:100% !important;height:auto !important;max-height:60vh;
    border-radius:20px 20px 0 0 !important;
    transform:translateY(100%) !important;
    flex-direction:column !important;flex-wrap:nowrap !important;
    align-items:stretch !important;justify-content:flex-start !important;
    padding:16px 20px calc(20px + env(safe-area-inset-bottom)) !important;
    gap:10px !important;
    z-index:9500 !important;
    background:rgba(10,10,15,.95) !important;
    backdrop-filter:blur(24px) !important;-webkit-backdrop-filter:blur(24px) !important;
    border-top:1px solid rgba(255,255,255,.06) !important;
  }
  .hp-tip-slider.show{transform:translateY(0) !important}
  /* Drag handle */
  .hp-tip-slider::before{
    content:'';width:40px;height:4px;background:rgba(255,255,255,.15);
    border-radius:2px;margin:0 auto 8px;display:block;flex-shrink:0;
  }
  /* Close button bigger */
  .hp-tip-x{font-size:22px !important;position:absolute !important;top:12px;right:16px}
  /* Tip label */
  .hp-tip-label{font-size:14px !important;font-weight:800 !important;margin-bottom:4px !important;text-align:center}
  /* Toggle tabs — full width */
  .otip-toggle{display:flex !important;width:100% !important;gap:0 !important;
    background:rgba(255,255,255,.06) !important;border-radius:10px !important;padding:3px !important}
  .otip-toggle button{flex:1 !important;padding:10px !important;font-size:13px !important;
    font-weight:700 !important;border-radius:8px !important;text-align:center !important}
  .otip-toggle button.active{background:var(--gold) !important;color:#000 !important}
  /* Tip amount buttons — 2×2 grid */
  .hp-ceed-btns,.hp-card-btns,.hp-instant-btns{
    display:grid !important;grid-template-columns:1fr 1fr !important;
    gap:8px !important;width:100% !important;
  }
  .hotip,.hp-instant-btns button{
    padding:14px !important;font-size:15px !important;font-weight:800 !important;
    border-radius:10px !important;min-height:48px !important;
    display:flex !important;align-items:center !important;justify-content:center !important;
  }
  /* Hide floating TIP tab on mobile — use action button instead */
  .hp-tip-tab{display:none !important}

  /* ══ Mobile: Queue — full screen overlay ══ */
  .hp-q-overlay{
    position:fixed !important;inset:0 !important;
    width:100% !important;height:100% !important;
    border-radius:0 !important;border:none !important;
    background:rgba(10,10,15,.97) !important;
    backdrop-filter:blur(20px) !important;-webkit-backdrop-filter:blur(20px) !important;
    z-index:9500 !important;
    transform:translateY(100%) !important;
  }
  .hp-q-overlay.show{transform:translateY(0) !important}
  .hp-q-hdr{padding:16px 20px !important;border-bottom:1px solid rgba(255,255,255,.06) !important}
  .hp-q-hdr span{font-size:16px !important}
  .hp-q-hdr button{font-size:24px !important;padding:4px 8px !important}
  .hp-q-list{padding:0 12px !important}
  /* Hide floating queue tab on mobile */
  .hp-q-toggle{display:none !important}

  /* ══ Mobile: Channel Slider — bottom sheet ══ */
  .hp-ch-slider{
    position:fixed !important;
    bottom:0 !important;left:0 !important;right:0 !important;
    border-radius:20px 20px 0 0 !important;
    background:rgba(10,10,15,.95) !important;
    backdrop-filter:blur(24px) !important;-webkit-backdrop-filter:blur(24px) !important;
    padding:20px 16px calc(16px + env(safe-area-inset-bottom)) !important;
    z-index:9500 !important;
    display:none;flex-wrap:wrap !important;gap:10px !important;
    justify-content:center !important;
  }
  .hp-ch-slider.show{display:flex !important;transform:translateY(0) !important}
  .hp-ch-btn{flex:1 !important;min-width:calc(50% - 5px) !important;
    padding:14px !important;font-size:13px !important;border-radius:10px !important;
    text-align:center !important;min-height:48px !important;
  }
  /* Hide floating channel tab on mobile */
  .hp-ch-tab{display:none !important}

  /* ══ Instagram UX: Comments Bottom Sheet ══ */
  .vf-comments-collapse #vfCommentsBody{
    position:fixed;
    bottom:0;
    left:0;
    right:0;
    max-height:60vh;
    background:var(--card);
    border-radius:16px 16px 0 0;
    z-index:9500;
    transform:translateY(100%);
    transition:transform .3s ease;
    overflow-y:auto;
    padding:16px 16px calc(16px + env(safe-area-inset-bottom));
    box-shadow:0 -8px 32px rgba(0,0,0,.3);
    display:block !important;
  }
  .vf-comments-collapse.open #vfCommentsBody{
    transform:translateY(0);
  }
  .vf-comments-collapse.open::after{
    content:'';
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.4);
    z-index:9499;
  }
  .vf-comments-drag-handle{
    width:40px;
    height:4px;
    background:rgba(255,255,255,.2);
    border-radius:2px;
    margin:0 auto 12px;
  }

  /* ══ Hero info below player on mobile ══ */
  [data-heroinfo]{
    position:relative;
    z-index:5;
    padding:8px 12px 4px !important;
    margin-top:0 !important;
  }
  /* Ensure nothing blocks the iframe on mobile */
  .hp-viz{z-index:1;position:relative}
  /* Action buttons — horizontal row under hero on mobile */
  .vf-hero-action-btns{
    position:static !important;
    display:flex !important;
    flex-direction:row !important;
    flex-wrap:nowrap !important;
    gap:0 !important;
    width:100% !important;
    justify-content:space-evenly !important;
    padding:8px 0 4px !important;
    border-top:1px solid rgba(255,255,255,.06);
  }
  .vf-hero-action-btns > span[style*="flex:1"]{display:none !important}
  /* Hide ALL instant tips on mobile */
  .vf-instant-tip-hero{display:none !important}
  .vf-mobile-tips{display:none !important}
  /* Each button: icon on top, tiny label below */
  .vf-hero-action-btn{
    width:auto !important;
    height:auto !important;
    border-radius:0 !important;
    padding:6px 2px !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    justify-content:center !important;
    gap:2px !important;
    background:none !important;
    border:none !important;
    color:rgba(255,255,255,.5) !important;
    font-size:17px !important;
    min-width:0 !important;
    box-shadow:none !important;
    flex:1 !important;
  }
  .vf-hero-action-btn:active{color:#fff !important}
  /* Show labels under icons */
  .vf-hero-action-btns .vf-btn-label{
    display:block !important;
    font-size:8px !important;
    font-weight:600 !important;
    color:inherit !important;
  }
  /* Queue toggle — visible always on mobile */
  .hp-q-toggle{
    opacity:1 !important;
    position:absolute !important;
    top:auto !important;
    bottom:4px !important;
    right:8px !important;
    transform:none !important;
    writing-mode:horizontal-tb !important;
    border-radius:8px !important;
    padding:6px 12px !important;
    font-size:9px !important;
  }
  /* Channel tab — visible always on mobile */
  .hp-ch-tab{
    opacity:1 !important;
    position:absolute !important;
    bottom:4px !important;
    left:8px !important;
    top:auto !important;
    transform:none !important;
    writing-mode:horizontal-tb !important;
    border-radius:8px !important;
    padding:6px 12px !important;
    font-size:12px !important;
  }
  /* Fullscreen button — larger touch target */
  .hp-fs-btn{
    width:40px !important;
    height:40px !important;
    font-size:18px !important;
  }
  /* Hero title in bar — show on mobile */
  .hp-bar{padding:4px 8px 0 !important}
  .hp-bar-title{display:block !important;font-size:11px !important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70vw}

  /* ══ Filter chips — flat text tabs, no icons ══ */
  .vf-filter-chip{
    flex-direction:row !important;
    width:auto !important;
    height:auto !important;
  }
  .vf-filter-chip::before{
    display:none !important;
    content:none !important;
    width:0 !important;height:0 !important;border:none !important;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:20px;
    background:var(--card);
  }
  .vf-filter-chip.active{
    background:none;
    color:var(--accent);
  }
  .vf-filter-chip.active::before{
    border-color:var(--accent);
    background:linear-gradient(135deg, rgba(12,155,141,.1), rgba(12,155,141,.05));
  }
  .vf-filter-chip:hover{
    border-color:transparent;
  }
}
@media(max-width:480px){
  .vf-header{padding:0 6px;gap:4px;height:36px}
  .vf-logo-text{display:none}
  .vf-logo-badge{display:none}
  .vf-balance{font-size:9px;padding:2px 6px}
  .vf-ceed-ticker{display:none}
  .vf-music-bar{padding:0 12px}
  .vf-music-bar-controls .vf-music-bar-btn:not(.vf-music-bar-play){display:none}
  .vf-main{margin-top:36px;padding:0;scroll-margin-top:36px}
  /* Even smaller avatar */
  .vf-card-avatar{width:28px;height:28px;font-size:11px}
  .vf-card-title-new{font-size:12px}
  .vf-card-meta-new{font-size:10px}
  .vf-hero-info .vf-hero-title{font-size:13px}
  /* Video filters handled by timeline panel mobile rules */
  #videoHeroLayout{margin-top:22px !important}
}

/* ═══ SHIMMER / SCROLLBAR ═══ */
.vf-shimmer{background:linear-gradient(90deg,var(--shimmer-a) 25%,var(--shimmer-b) 50%,var(--shimmer-a) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.vf-shimmer-block{height:60px;margin-bottom:8px}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--tx3)}

/* ═══ THEME TOGGLE ═══ */
.vf-theme-toggle{width:36px;height:36px;border-radius:var(--r-btn);border:1px solid var(--border);background:var(--bg2);color:var(--tx2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .15s;flex-shrink:0}
.vf-theme-toggle:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-l)}
/* Sign-in modal */
.vf-auth-overlay{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center}
.vf-auth-overlay.show{display:flex}
.vf-auth-modal{background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:32px;max-width:380px;width:90%;box-shadow:0 12px 48px rgba(0,0,0,.4);text-align:center;position:relative}
.vf-auth-modal h2{font-size:20px;font-weight:800;margin-bottom:6px}
.vf-auth-modal p{font-size:13px;color:var(--tx2);margin-bottom:20px;line-height:1.5}
.vf-auth-close{position:absolute;top:12px;right:16px;background:none;border:none;color:var(--tx3);font-size:20px;cursor:pointer}
.vf-auth-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:13px;border-radius:50px;border:none;font-family:var(--font);font-size:14px;font-weight:700;cursor:pointer;transition:transform .15s;margin-bottom:10px}
.vf-auth-btn:hover{transform:scale(1.02)}
.vf-auth-btn.google{background:#fff;color:#333}
.vf-auth-btn.email{background:var(--accent);color:#fff}
.vf-auth-btn.ceed{background:linear-gradient(135deg,#FFD700,#FF8C00);color:#000}
.vf-auth-divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--tx3);font-size:11px;text-transform:uppercase;letter-spacing:1px}
.vf-auth-divider::before,.vf-auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.vf-auth-input{width:100%;padding:12px 16px;border-radius:12px;border:1px solid var(--border);background:var(--bg3);color:var(--tx);font-family:var(--font);font-size:14px;margin-bottom:10px;box-sizing:border-box}
.vf-auth-input:focus{outline:none;border-color:var(--accent)}
.vf-auth-toggle{font-size:12px;color:var(--accent);cursor:pointer;margin-top:8px;background:none;border:none;font-family:var(--font)}
.vf-auth-error{font-size:12px;color:#FF5252;margin-bottom:10px}
/* ── NFT Cards ── */
.vf-nft-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r,12px);padding:14px;position:relative;overflow:hidden}
.vf-nft-card .nft-stage-bar{height:6px;border-radius:3px;background:var(--bg3);overflow:hidden;margin-top:8px}
.vf-nft-card .nft-stage-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--accent),var(--gold,#f5a623));transition:width .4s ease}
.vf-nft-card .nft-stage-dots{display:flex;gap:4px;margin-top:6px}
.vf-nft-card .nft-stage-dots span{width:8px;height:8px;border-radius:50%;background:var(--bg3);transition:background .3s}
.vf-nft-card .nft-stage-dots span.active{background:var(--accent)}
.vf-nft-badge{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:10px;text-align:center;position:relative;animation:nftGlow 3s ease-in-out infinite}
@keyframes nftGlow{0%,100%{box-shadow:0 0 6px rgba(12,155,141,.15)}50%{box-shadow:0 0 16px rgba(12,155,141,.35)}}
.vf-nft-mint-btn{padding:6px 12px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;font-size:10px;font-weight:700;border-radius:8px;cursor:pointer;font-family:var(--font);margin-top:6px}
.vf-nft-mint-btn:hover{opacity:.85}
.vf-nft-frac-btn{padding:5px 10px;background:linear-gradient(135deg,var(--gold,#f5a623),#e09800);border:none;color:#000;font-size:10px;font-weight:700;border-radius:8px;cursor:pointer;font-family:var(--font);margin-top:4px}
.vf-dm-btn{padding:6px 12px;background:var(--card);border:1px solid var(--border);color:var(--tx2);font-size:11px;font-weight:700;border-radius:10px;cursor:pointer;font-family:var(--font);display:inline-flex;align-items:center;gap:4px}
.vf-dm-btn:hover{border-color:var(--accent);color:var(--accent)}

/* ═══ VERIFIED BADGE ═══ */
.vf-verified{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--accent);color:#fff;font-size:9px;margin-right:4px;margin-left:0;vertical-align:middle;flex-shrink:0}

/* ═══ VIDEO REACTIONS (removed) ═══ */

/* ═══ VIDEO COMMENTS ═══ */
.vf-comments{margin-top:12px;padding:0 4px;border:none;background:transparent}
.vf-comments-header{display:flex;align-items:center;gap:8px;cursor:pointer;padding:6px 0;user-select:none}
.vf-comments-header .vf-ch-icon{font-size:12px;transition:transform .2s}
.vf-comments-header.open .vf-ch-icon{transform:rotate(90deg)}
.vf-comments-count{font-size:12px;font-weight:700;color:var(--tx2)}
.vf-comment-input{display:flex;gap:8px;align-items:flex-start;margin:8px 0}
.vf-comment-input textarea{flex:1;padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:var(--card);color:var(--tx);font-size:12px;font-family:var(--font);resize:none;min-height:36px;max-height:80px;outline:none;transition:border-color .15s}
.vf-comment-input textarea:focus{border-color:var(--accent)}
.vf-comment-input button{padding:8px 14px;border-radius:10px;border:none;background:var(--accent);color:#fff;font-size:11px;font-weight:700;cursor:pointer;font-family:var(--font);white-space:nowrap;flex-shrink:0}
.vf-comment-input button:disabled{opacity:.4;cursor:default}
.vf-comment-signin{font-size:11px;color:var(--tx3);padding:6px 0}
.vf-comment-signin a{color:var(--accent);cursor:pointer;font-weight:600;text-decoration:none}
.vf-comment-list{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.vf-comment{display:flex;gap:8px;align-items:flex-start;padding:6px 0}
.vf-comment-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-l);color:var(--accent);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.vf-comment-body{flex:1;min-width:0}
.vf-comment-name{font-size:11px;font-weight:700;color:var(--tx)}
.vf-comment-text{font-size:12px;color:var(--tx2);line-height:1.4;margin-top:2px;word-break:break-word}
.vf-comment-footer{display:flex;align-items:center;gap:10px;margin-top:3px}
.vf-comment-time{font-size:9px;color:var(--tx2)}
.vf-comment-like{display:inline-flex;align-items:center;gap:3px;font-size:10px;color:var(--tx3);cursor:pointer;border:none;background:none;padding:0;font-family:var(--font)}
.vf-comment-like:hover{color:var(--accent)}
.vf-comments-more{font-size:11px;color:var(--accent);font-weight:600;cursor:pointer;padding:4px 0;border:none;background:none;font-family:var(--font)}
/* ═══ YT-INSPIRED VIDEO CARDS ═══ */
.vf-card-new{position:relative;width:100%;margin-bottom:2px;overflow:hidden;cursor:pointer;transition:opacity .15s}
.vf-card-new:hover{transform:none;opacity:.9}
.vf-card-new .vf-card-thumb{position:relative;border-radius:0;overflow:hidden;aspect-ratio:16/9;background:#111}
.vf-card-new .vf-card-thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(transparent 30%,rgba(0,0,0,.75) 100%);pointer-events:none;z-index:1}
.vf-card-new .vf-card-thumb img{width:100%;height:100%;object-fit:cover}
.vf-card-new .vf-card-duration{position:absolute;bottom:6px;right:6px;background:rgba(0,0,0,.8);color:#fff;font-size:10px;font-weight:700;padding:2px 5px;border-radius:4px}
.vf-card-new .vf-card-exclusive{position:absolute;top:6px;left:6px;background:linear-gradient(135deg,#FFD700,#FF8C00);color:#000;font-size:9px;font-weight:800;padding:2px 7px;border-radius:6px;letter-spacing:.4px;z-index:2}
.vf-card-new .vf-card-price{position:absolute;bottom:6px;left:6px;background:rgba(0,0,0,.75);color:#FFD700;font-size:10px;font-weight:700;padding:2px 6px;border-radius:6px;z-index:2}
.vf-card-new .vf-card-episodes{position:absolute;top:6px;right:6px;background:rgba(0,0,0,.75);color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:6px;z-index:2}
.vf-card-new .vf-card-unlocks{position:absolute;bottom:6px;left:6px;background:rgba(0,0,0,.75);color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:6px;z-index:2}
.vf-card-new .vf-pl-add{position:absolute;bottom:6px;right:6px;width:26px;height:26px;border-radius:50%;border:none;background:rgba(0,0,0,.7);color:#fff;font-size:16px;line-height:1;cursor:pointer;z-index:3;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}
.vf-card-new:hover .vf-pl-add{opacity:1!important}
.vf-card-new .vf-card-report{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;border:none;background:rgba(0,0,0,.65);color:rgba(255,255,255,.7);font-size:11px;line-height:1;cursor:pointer;z-index:3;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}
.vf-card-new:hover .vf-card-report{opacity:1}
.vf-card-new .vf-card-report:hover{color:#ef4444}
.vf-card-info{position:absolute;bottom:0;left:0;right:0;z-index:2;display:flex;gap:10px;padding:14px 16px;background:transparent}
.vf-card-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;border:1.5px solid rgba(255,255,255,.3)}
.vf-card-text{flex:1;min-width:0}
.vf-card-title-new{font-size:15px;font-weight:700;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.5)}
.vf-card-meta-new{font-size:11px;color:rgba(255,255,255,.6);margin-top:3px}

/* ═══ UP NEXT ROW ═══ */
.vf-upnext-row{display:flex;gap:12px;overflow-x:auto;padding:8px 0 12px;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;scrollbar-width:none}
.vf-upnext-row::-webkit-scrollbar{display:none}
.vf-upnext-card{flex-shrink:0;width:200px;cursor:pointer;scroll-snap-align:start;transition:opacity .15s}
.vf-upnext-card:hover{opacity:.9}
.vf-upnext-thumb{width:200px;height:112px;border-radius:8px;overflow:hidden;background:#111;position:relative;border:none;box-shadow:none}
.vf-upnext-thumb img{width:100%;height:100%;object-fit:cover}
.vf-upnext-title{font-size:11px;font-weight:600;margin-top:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vf-upnext-creator{font-size:10px;color:var(--tx3);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vf-upnext-seeall{flex-shrink:0;width:80px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--accent);cursor:pointer;white-space:nowrap}
.vf-upnext-seeall:hover{text-decoration:underline}

/* ═══ FILTER BAR (Vellow-inspired) ═══ */
/* ═══ CHANNEL SELECTOR ═══ */
.vf-ch-tab{padding:8px 18px;border:none;border-bottom:2px solid transparent;background:transparent;color:rgba(255,255,255,.4);font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all .15s}
.vf-ch-tab:hover{color:rgba(255,255,255,.7)}
.vf-ch-tab.active{border-bottom-color:var(--accent);background:rgba(255,255,255,.04);color:#fff;font-weight:700}

/* ═══ TIMELINE PANEL ═══ */
.vf-timeline-panel .vf-grid{display:flex!important;overflow-x:auto!important;overflow-y:hidden!important;gap:10px!important;margin-bottom:0!important;padding:8px!important;scroll-snap-type:x mandatory!important;-webkit-overflow-scrolling:touch!important;scrollbar-width:none!important}
.vf-timeline-panel .vf-grid::-webkit-scrollbar{display:none}
.vf-timeline-panel .vf-grid .vf-card,.vf-timeline-panel .vf-grid .vf-card-new{width:calc((100% - 40px) / 5)!important;min-width:calc((100% - 40px) / 5)!important;max-width:calc((100% - 40px) / 5)!important;flex-shrink:0!important;scroll-snap-align:start!important}
.vf-timeline-panel .s-tile{min-width:160px!important;max-width:180px!important;flex-shrink:0!important;scroll-snap-align:start!important}
.vf-timeline-panel #mvGrid{display:flex!important;overflow-x:auto!important;gap:10px!important;scrollbar-width:none!important;scroll-snap-type:x mandatory!important}
.vf-timeline-panel #mvGrid::-webkit-scrollbar{display:none}
.vf-timeline-panel #mvGrid>*{min-width:140px!important;max-width:160px!important;flex-shrink:0!important;scroll-snap-align:start!important}

/* ═══ FILTER BAR (Vellow track-style) ═══ */
.vf-filter-bar{display:flex!important;flex-direction:column!important;gap:0!important;padding:0!important;margin:0 0 16px!important;border-radius:8px!important;overflow:hidden!important;border:1px solid rgba(255,255,255,.06)!important;background:rgba(255,255,255,.02)!important}
.vf-filter-bar::-webkit-scrollbar{display:none}
.vf-filter-bar .vf-filter-chip{display:flex!important;align-items:center!important;padding:10px 16px!important;border:none!important;border-bottom:1px solid rgba(255,255,255,.04)!important;border-left:3px solid transparent!important;border-radius:0!important;background:transparent!important;color:rgba(255,255,255,.45)!important;font-size:12px!important;font-weight:600!important;cursor:pointer;font-family:var(--font);width:100%!important;text-align:left!important;transition:all .15s!important}
.vf-filter-bar .vf-filter-chip:last-child{border-bottom:none!important}
.vf-filter-bar .vf-filter-chip:hover{background:rgba(255,255,255,.04)!important;color:rgba(255,255,255,.7)!important}
.vf-filter-bar .vf-filter-chip.active{background:rgba(12,155,141,.12)!important;color:#fff!important;border-left-color:var(--accent)!important}
/* Legacy filter chips (compat) */
.vf-filter-chips{display:flex;gap:14px;overflow-x:auto;padding:8px 0;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.vf-filter-chips::-webkit-scrollbar{display:none}
.vf-filter-chip{padding:6px 0;border-radius:0;border:none;background:none;color:var(--tx3);font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font);white-space:nowrap;transition:color .15s;flex-shrink:0}
.vf-filter-chip:hover{color:var(--tx);border-color:transparent;background:none}
.vf-filter-chip.active{color:var(--accent);border:none;background:none;font-weight:800}

/* ═══ HERO INFO (YT-STYLE) ═══ */
.vf-hero-info{padding:12px 0}
.vf-hero-info .vf-hero-top{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.vf-hero-info .vf-hero-creator{font-size:12px;font-weight:700;color:var(--tx2);white-space:nowrap}
.vf-hero-info .vf-hero-title{font-size:15px;font-weight:800;flex:1;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.vf-hero-info .vf-hero-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.vf-hero-action-btn{padding:6px 14px;border-radius:10px;border:1px solid var(--border);background:var(--card);color:var(--tx2);font-size:11px;font-weight:700;cursor:pointer;font-family:var(--font);display:inline-flex;align-items:center;gap:4px;transition:all .15s;white-space:nowrap}
.vf-hero-action-btn:hover{border-color:var(--accent);color:var(--accent)}
.vf-hero-action-btn.book{background:linear-gradient(135deg,var(--accent),#0ab89a);border-color:transparent;color:#fff}
.vf-hero-action-btn.book:hover{opacity:.9}
.vf-hero-action-btn.tip{border-color:var(--gold,#C8A23C);color:var(--gold,#C8A23C)}
.vf-hero-action-btn.tip:hover{background:rgba(201,147,18,.08)}
/* ── Instant Tip buttons — transparent box with hero shadow glow ── */
.vf-instant-tip-hero{
  padding:6px 14px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);
  color:var(--tx2);font-size:11px;font-weight:700;font-family:var(--font);cursor:pointer;
  transition:transform .25s ease,box-shadow .3s ease,border-color .2s,background .2s;
  white-space:nowrap;display:inline-flex;align-items:center;gap:4px
}
.vf-instant-tip-hero:hover{
  transform:translateY(-4px);color:#fff;
  border-color:rgba(var(--glow-r),var(--glow-g),var(--glow-b),.25);
  background:rgba(var(--glow-r),var(--glow-g),var(--glow-b),.06);
  box-shadow:
    0 4px 16px rgba(var(--glow-r),var(--glow-g),var(--glow-b),.25),
    0 8px 32px rgba(var(--glow-r),var(--glow-g),var(--glow-b),.15),
    0 16px 60px rgba(var(--glow-r2),var(--glow-g2),var(--glow-b2),.1)
}
.vf-instant-tip-hero:active{transform:scale(.95)}
@media(max-width:768px){
  .vf-instant-tip-hero{padding:6px 12px;font-size:12px}
}

/* ═══ AUTOPLAY/SHUFFLE TOGGLES ═══ */
.vf-toggle-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:14px;border:none;background:transparent;color:var(--tx3);font-size:10px;font-weight:700;cursor:pointer;font-family:var(--font);transition:all .15s;user-select:none}
.vf-toggle-pill.on{background:transparent;border:none;color:var(--accent)}
.vf-toggle-dot{width:6px;height:6px;border-radius:50%;background:var(--tx3);transition:background .15s}
.vf-toggle-pill.on .vf-toggle-dot{background:var(--accent)}

/* ═══ COMMENTS COLLAPSE ═══ */
.vf-comments-collapse{margin-top:16px;border-top:none;padding-top:8px}
.vf-comments-collapse .vf-comments-header{padding:10px 0}
.vf-comments-collapse .vf-comments-header:not(.open)+#vfCommentsBody{display:none}

/* ═══ ACCESSIBILITY ═══ */
.vf-skip-link{position:absolute;top:-100px;left:0;background:var(--accent);color:#fff;padding:8px 16px;z-index:99999;font-weight:700;border-radius:0 0 8px 0;transition:top .2s;text-decoration:none;font-family:var(--font);font-size:14px}
.vf-skip-link:focus{top:0}
/* Bottom tab bar — hidden on desktop, shown on mobile */
.vf-bottom-tabs{display:none;position:fixed;bottom:0;left:0;right:0;z-index:9000;background:var(--bg);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom);transition:transform .3s ease}
.vf-bottom-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;padding:6px 0;cursor:pointer;color:var(--tx3);transition:color .15s;-webkit-tap-highlight-color:transparent;border:none;background:none;font-family:var(--font);position:relative}
.vf-bottom-tab:active{transform:scale(.92)}
.vf-bottom-tab.active{color:var(--accent)}
.vf-bottom-tab.active::after{display:none}
.vf-bottom-tab .bt-icon{font-size:20px;line-height:1}
.vf-bottom-tab .bt-label{font-size:9px;font-weight:600}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms !important;transition-duration:0.01ms !important}
}
/* ═══ CREATOR ONBOARDING WIZARD ═══ */
.vf-onboard-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px)}
.vf-onboard-card{background:var(--card,#1a1a2e);border:1px solid var(--border);border-radius:16px;padding:32px 28px 24px;max-width:420px;width:100%;position:relative;text-align:center}
.vf-onboard-icon{font-size:40px;margin-bottom:12px}
.vf-onboard-title{font-size:18px;font-weight:800;color:var(--tx1);margin-bottom:8px}
.vf-onboard-desc{font-size:13px;color:var(--tx3);line-height:1.5;margin-bottom:20px}
.vf-onboard-dots{display:flex;justify-content:center;gap:8px;margin-bottom:20px}
.vf-onboard-dot{width:10px;height:10px;border-radius:50%;background:var(--border);transition:background .2s}
.vf-onboard-dot.active{background:var(--accent)}
.vf-onboard-dot.done{background:var(--gold)}
.vf-onboard-nav{display:flex;gap:10px;justify-content:center;margin-top:16px}
.vf-onboard-nav button{padding:10px 24px;border-radius:10px;border:none;font-size:13px;font-weight:700;cursor:pointer;font-family:var(--font)}
.vf-onboard-next{background:var(--accent);color:#fff}
.vf-onboard-back{background:var(--bg2);color:var(--tx2);border:1px solid var(--border)!important}
.vf-onboard-skip{display:block;margin:12px auto 0;background:none;border:none;color:var(--tx3);font-size:11px;cursor:pointer;font-family:var(--font);text-decoration:underline}
.vf-onboard-input{width:100%;padding:10px 14px;border-radius:10px;border:1px solid var(--border);background:var(--bg2);color:var(--tx1);font-size:13px;font-family:var(--font);margin-bottom:8px;box-sizing:border-box}
/* ═══ CONTENT REPORTING ═══ */
.vf-report-btn{background:none;border:none;color:var(--tx3);font-size:11px;cursor:pointer;font-family:var(--font);padding:4px 8px;border-radius:6px;opacity:.6;transition:opacity .2s}
.vf-report-btn:hover{opacity:1;color:var(--red,#ef4444)}
.vf-report-form{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px;margin-top:10px}
.vf-report-form select,.vf-report-form textarea{width:100%;padding:8px 10px;border-radius:8px;border:1px solid var(--border);background:var(--bg2);color:var(--tx1);font-size:12px;font-family:var(--font);margin-bottom:8px;box-sizing:border-box}
.vf-report-form textarea{resize:vertical;min-height:60px}
.vf-report-submit{padding:8px 18px;border-radius:8px;border:none;background:var(--red,#ef4444);color:#fff;font-size:12px;font-weight:700;cursor:pointer;font-family:var(--font)}
.vf-card .vf-card-report{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:50%;border:none;background:rgba(0,0,0,.65);color:rgba(255,255,255,.7);font-size:12px;line-height:1;cursor:pointer;z-index:3;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}
.vf-card:hover .vf-card-report{opacity:1}
.vf-card .vf-card-report:hover{color:#ef4444}
/* ═══ WATCH HISTORY / CONTINUE WATCHING ═══ */
.vf-cw-section{margin-bottom:20px}
.vf-cw-scroll{display:flex;gap:12px;overflow-x:auto;padding:4px 0 12px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.vf-cw-card{flex:0 0 200px;scroll-snap-align:start;background:var(--card);border:1px solid var(--border);border-radius:var(--r,12px);overflow:hidden;cursor:pointer;position:relative;transition:transform .2s}
.vf-cw-card:hover{transform:translateY(-2px)}
.vf-cw-thumb{width:100%;aspect-ratio:16/9;background:var(--bg3);position:relative;overflow:hidden}
.vf-cw-thumb img{width:100%;height:100%;object-fit:cover}
.vf-cw-body{padding:8px 10px}
.vf-cw-title{font-size:12px;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:3px}
.vf-cw-meta{font-size:10px;color:var(--tx3)}
.vf-cw-remove{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;border:none;background:rgba(0,0,0,.7);color:#fff;font-size:12px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;z-index:2}
.vf-cw-card:hover .vf-cw-remove{opacity:1}
.vf-cw-clear{font-size:11px;color:var(--tx3);cursor:pointer;border:none;background:none;font-family:var(--font);text-decoration:underline;white-space:nowrap;flex-shrink:0;align-self:center}

/* ── #24: Mobile Bottom Sheet for Messages ── */
@media(max-width:768px){
  .vf-msg-panel{
    position:fixed!important;top:auto!important;bottom:0!important;left:0!important;right:0!important;
    width:100%!important;max-width:100%!important;height:85vh!important;max-height:85vh!important;
    border-radius:16px 16px 0 0!important;
    transform:translateY(100%);transition:transform .3s ease!important;
    display:flex!important;flex-direction:column!important;
  }
  .vf-msg-panel.show{transform:translateY(0)!important}
  .vf-msg-hdr{border-radius:16px 16px 0 0;padding:12px 16px}
  .vf-msg-hdr::before{content:'';display:block;width:36px;height:4px;background:rgba(255,255,255,.2);border-radius:2px;margin:0 auto 8px}
}

/* ── #17: Connection Banner ── */
.vf-conn-banner{position:fixed;top:56px;left:0;right:0;z-index:9999;background:#ff4444;color:#fff;text-align:center;padding:6px;font-size:11px;font-weight:700;font-family:var(--font);transition:transform .3s}

/* ── Live Features ── */
@keyframes giftFloat{from{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-200px) scale(1.5)}}
.vf-live-gift{position:absolute;right:20px;bottom:80px;font-size:32px;pointer-events:none;animation:giftFloat 2s ease-out forwards;z-index:100}
.vf-live-chat{display:flex;flex-direction:column;background:rgba(0,0,0,.3);border-radius:12px;overflow:hidden;max-height:300px}
.vf-live-chat-messages{flex:1;overflow-y:auto;padding:8px;scrollbar-width:none;display:flex;flex-direction:column-reverse}
.vf-live-chat-messages::-webkit-scrollbar{display:none}
.vf-live-chat-msg{padding:3px 0;font-size:11px;color:rgba(255,255,255,.8)}
.vf-live-chat-msg .chat-name{color:var(--accent);font-weight:700;margin-right:4px}
.vf-live-chat-input{display:flex;gap:4px;padding:6px 8px;border-top:1px solid rgba(255,255,255,.08)}
.vf-live-chat-input input{flex:1;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:6px 12px;color:#fff;font-size:11px;outline:none;font-family:var(--font)}
.vf-live-chat-input button{background:var(--accent);color:#fff;border:none;border-radius:50%;width:28px;height:28px;cursor:pointer;font-size:12px;flex-shrink:0}
.vf-go-live-fab{position:fixed;bottom:76px;left:16px;z-index:8999;width:48px;height:48px;border-radius:50%;background:#ff4444;color:#fff;border:none;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(255,0,0,.3);animation:pulse 2s infinite}
@media(min-width:769px){.vf-go-live-fab{bottom:24px;left:24px}}
.vf-live-battle{display:grid;grid-template-columns:1fr 1fr;gap:2px;aspect-ratio:16/9;background:#000;border-radius:12px;overflow:hidden}
.vf-live-battle iframe{width:100%;height:100%;border:none}
.vf-live-vote-bar{height:4px;background:rgba(255,255,255,.1);border-radius:2px;margin:8px 0;overflow:hidden;display:flex}
.vf-live-vote-bar .left{background:var(--accent);transition:width .3s}
.vf-live-vote-bar .right{background:var(--gold);transition:width .3s}

/* ── Mobile: all new features ── */
@media(max-width:768px){
  /* Messages panel — full-width bottom sheet */
  .vf-msg-panel{position:fixed!important;top:auto!important;bottom:0!important;left:0!important;right:0!important;width:100%!important;max-width:100%!important;height:85vh!important;max-height:85vh!important;border-radius:16px 16px 0 0!important;transform:translateY(100%);transition:transform .3s ease!important;display:flex!important;flex-direction:column!important}
  .vf-msg-panel.show{transform:translateY(0)!important}
  .vf-msg-hdr::before{content:'';display:block;width:36px;height:4px;background:rgba(255,255,255,.2);border-radius:2px;margin:0 auto 8px}

  /* Below-hero grids — single column */
  #vfBelowSports .vf-grid,#vfBelowSportsGrid{grid-template-columns:1fr!important}
  #vfBelowMovies .vf-grid,#vfBelowMoviesGrid{grid-template-columns:repeat(2,1fr)!important;gap:8px!important}

  /* Music timeline — full width */
  #musicTimeline{padding:8px 8px 0}
  #musicTimelineSlider{height:32px}
  #musicTimelineThumb{width:18px;height:18px;opacity:1!important}

  /* Go Live FAB — above bottom tabs */
  #goLiveFloatBtn{bottom:72px!important;left:12px!important}

  /* Mini players — full width stacked */
  .vf-mini-spawn{width:100%!important;left:0!important;right:0!important;border-radius:12px 12px 0 0!important}

  /* Seeds detail overlay */
  #seedDetailOverlay>div{width:95%!important;max-width:none!important}

  /* Live chat panel */
  .vf-live-chat{max-height:200px}

  /* Bottom tabs — scrollable with 7 items */
  .vf-bottom-tabs{overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
  .vf-bottom-tabs::-webkit-scrollbar{display:none}
  .vf-bottom-tab{min-width:52px;flex:0 0 auto}
}

/* ── Mobile: Seeds + Live features ── */
@media(max-width:480px){
  /* Seeds compose — tighter padding */
  #seedCompose{padding:10px!important}
  #seedCompose textarea{font-size:13px!important}

  /* Seeds trending pills — wrap */
  #seedTrending{overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;flex-wrap:nowrap!important;white-space:nowrap}
  #seedTrending::-webkit-scrollbar{display:none}

  /* Seeds follow/discover tabs — full width */
  #seedFilterTabs{display:flex!important;width:100%}
  #seedFilterTabs button{flex:1}

  /* Seed card actions — smaller text */
  .seed-action-row{gap:10px!important}
  .seed-action-row button{font-size:10px!important}

  /* Poll options — full width */
  #seedPollUI input{font-size:12px!important}

  /* Quote reseed popup */
  #reseedPopup>div{width:90%!important;max-width:none!important}

  /* Go Live modal */
  .go-live-modal>div{width:95%!important;max-width:none!important}

  /* Live gift bar — scrollable */
  .vf-gift-bar{overflow-x:auto;scrollbar-width:none;flex-wrap:nowrap!important;gap:4px!important}
  .vf-gift-bar::-webkit-scrollbar{display:none}
  .vf-gift-btn{flex:0 0 auto!important;padding:4px 8px!important;font-size:10px!important}

  /* Battle view — stack vertically */
  .vf-live-battle{grid-template-columns:1fr!important;aspect-ratio:9/16!important}

  /* Scheduled streams — single column */
  #scheduledGrid{grid-template-columns:1fr!important}

  /* Live leaderboard */
  .vf-live-leaderboard{font-size:10px!important}
}
