/* =====================================================
   Shopee Video Site — Custom CSS (Bootstrap 5 layer)
   Dark theme: #05080d / accent: #fc5100
   ===================================================== */

:root {
    --v-bg:       #05080d;
    --v-bg2:      #0d1117;
    --v-bg3:      #161b22;
    --v-border:   #21262d;
    --v-accent:   #fc5100;
    --v-accent2:  #ff6b35;
    --v-text:     #e6edf3;
    --v-text2:    #8b949e;
    --v-text3:    #6e7681;
    --v-sidebar:  220px;
    --v-header:   60px;
    --v-radius:   10px;
}

/* ── BASE ─────────────────────────────────────────── */
body {
    background: var(--v-bg);
    color: var(--v-text);
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    min-height: 100vh;
}

a { color: inherit; text-decoration: none; }
a:hover { color: inherit; }

::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--v-bg2); }
::-webkit-scrollbar-thumb { background: var(--v-border); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--v-text3); }

/* ── BOOTSTRAP OVERRIDES ──────────────────────────── */
.bg-v-dark   { background-color: var(--v-bg) !important; }
.bg-v-card   { background-color: var(--v-bg2) !important; }
.bg-v-input  { background-color: var(--v-bg3) !important; }
.border-v    { border-color: var(--v-border) !important; }
.text-v      { color: var(--v-text) !important; }
.text-v2     { color: var(--v-text2) !important; }
.text-v3     { color: var(--v-text3) !important; }
.text-accent { color: var(--v-accent) !important; }

.btn-accent {
    background: var(--v-accent);
    color: #fff;
    border: none;
    font-weight: 600;
    transition: background .2s;
}
.btn-accent:hover { background: var(--v-accent2); color: #fff; }
.btn-accent-outline {
    border: 1px solid var(--v-accent);
    color: var(--v-accent);
    background: transparent;
    font-weight: 600;
    transition: all .2s;
}
.btn-accent-outline:hover { background: var(--v-accent); color: #fff; }

/* ── HEADER ───────────────────────────────────────── */
.v-header {
    position: fixed; top: 0; left: 0; right: 0;
    height: var(--v-header);
    background: rgba(5, 8, 13, 0.95);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--v-border);
    z-index: 1030;
    display: flex; align-items: center;
    padding: 0 16px; gap: 10px;
    /* needed for absolute-center search */
    position: fixed;
}

/* Logo: fixed, never shrinks */
.v-logo {
    display: flex; align-items: center; gap: 8px;
    font-weight: 800; font-size: 1.15rem; white-space: nowrap;
    color: var(--v-text);
    flex: 0 0 auto;
}
.v-logo-icon {
    width: 32px; height: 32px;
    background: var(--v-accent); border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
}
.v-logo em { color: var(--v-accent); font-style: normal; }

/* Search: normal flow version (fallback) */
.v-search-wrap {
    flex: 1 1 0;
    min-width: 0;
    max-width: 460px;
    display: flex; align-items: center;
    background: var(--v-bg3);
    border: 1px solid var(--v-border);
    border-radius: 50px;
    padding: 0 8px 0 14px;
    height: 38px;
    transition: border-color .2s;
}
.v-search-wrap:focus-within { border-color: var(--v-accent); }
.v-search-wrap input {
    flex: 1; background: none; border: none; outline: none;
    color: var(--v-text); font-size: .88rem;
    padding: 0 8px; min-width: 0;
}
.v-search-wrap input::placeholder { color: var(--v-text3); }
.v-search-wrap .btn-search {
    background: var(--v-accent); color: #fff; border: none;
    border-radius: 50px; padding: 4px 14px; font-size: .8rem;
    font-weight: 600; cursor: pointer; white-space: nowrap;
    transition: background .2s; flex-shrink: 0;
}
.v-search-wrap .btn-search:hover { background: var(--v-accent2); }

/* Search: absolute center override */
.v-search-center {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: min(460px, 40vw);
    flex: none;
    min-width: 0;
    max-width: none;
    z-index: 1;
}

/* Upload btn: fixed */
.v-header .btn-accent { flex: 0 0 auto; }

/* Right group (lang + avatar): fixed, never shrinks */
.v-header-right { flex: 0 0 auto; }

/* Hide search btn text on small screens */
@media (max-width: 640px) {
    .v-search-center { width: min(240px, 38vw); }
    .v-search-wrap .btn-search { display: none; }
    .v-logo span  { display: none; }
}

/* ── SIDEBAR ──────────────────────────────────────── */
.v-sidebar {
    position: fixed; top: var(--v-header); left: 0; bottom: 0;
    width: var(--v-sidebar);
    background: var(--v-bg2);
    border-right: 1px solid var(--v-border);
    overflow-y: auto; z-index: 1020;
    padding: 12px 0;
    transition: transform .3s ease;
}
.v-sidebar .nav-label {
    font-size: .68rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: .08em; color: var(--v-text3);
    padding: 10px 18px 4px;
}
.v-sidebar .nav-item a,
.v-sidebar .nav-link {
    display: flex; align-items: center; gap: 10px;
    padding: 9px 18px; color: var(--v-text2); font-size: .88rem;
    font-weight: 500; border-radius: 0; white-space: nowrap;
    transition: color .15s, background .15s;
    position: relative;
}
.v-sidebar .nav-item a:hover,
.v-sidebar .nav-link:hover { color: var(--v-text); background: var(--v-bg3); }
.v-sidebar .nav-link.active {
    color: var(--v-accent);
    background: rgba(252, 81, 0, .08);
}
.v-sidebar .nav-link.active::before {
    content: ''; position: absolute; left: 0; top: 0; bottom: 0;
    width: 3px; background: var(--v-accent); border-radius: 0 3px 3px 0;
}
.v-nav-badge {
    margin-left: auto;
    background: var(--v-accent); color: #fff;
    font-size: .62rem; font-weight: 700;
    padding: 1px 6px; border-radius: 50px;
}
.v-sidebar-divider { border-color: var(--v-border); margin: 6px 14px; }
.v-sidebar-tag {
    display: flex; align-items: center; gap: 8px;
    padding: 6px 18px; color: var(--v-text2);
    font-size: .82rem; transition: color .15s, background .15s;
}
.v-sidebar-tag:hover { color: var(--v-text); background: var(--v-bg3); }
.v-sidebar-tag .hash { color: var(--v-accent); font-weight: 700; }

/* ── MAIN LAYOUT ──────────────────────────────────── */
.v-body { padding-top: var(--v-header); }
.v-main  { margin-left: var(--v-sidebar); padding: 24px; }

/* ── VIDEO CARD ───────────────────────────────────── */
.v-card {
    background: var(--v-bg2);
    border: 1px solid var(--v-border) !important;
    border-radius: var(--v-radius) !important;
    overflow: hidden;
    transition: border-color .2s, transform .2s;
    display: block; color: var(--v-text);
}
.v-card:hover {
    border-color: var(--v-accent) !important;
    transform: translateY(-3px);
    color: var(--v-text);
}
.v-thumb {
    position: relative; aspect-ratio: 9/16;
    background: var(--v-bg3); overflow: hidden;
}
.v-thumb img { width: 100%; height: 100%; object-fit: cover; }
.v-thumb-placeholder {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    color: var(--v-text3);
}
.v-thumb-play {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    opacity: 0; transition: opacity .2s;
    background: rgba(0,0,0,.3);
}
.v-card:hover .v-thumb-play { opacity: 1; }
.v-thumb-play-btn {
    width: 44px; height: 44px; background: rgba(0,0,0,.65);
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
}
.v-thumb-views {
    position: absolute; bottom: 7px; left: 8px;
    color: #fff; font-size: .7rem; font-weight: 600;
    text-shadow: 0 1px 4px rgba(0,0,0,.8);
    display: flex; align-items: center; gap: 3px;
}
.v-thumb-duration {
    position: absolute; bottom: 7px; right: 8px;
    background: rgba(0,0,0,.72); color: #fff;
    font-size: .68rem; font-weight: 700;
    padding: 2px 6px; border-radius: 4px;
}
.v-thumb-badge {
    position: absolute; top: 7px; left: 8px;
    background: var(--v-accent); color: #fff;
    font-size: .62rem; font-weight: 700;
    padding: 2px 7px; border-radius: 50px;
}
.v-card-body { padding: 10px 12px; }
.v-card-title {
    font-size: .85rem; font-weight: 600; color: var(--v-text);
    line-height: 1.4; margin-bottom: 6px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.v-card-meta {
    display: flex; align-items: center; gap: 6px;
    font-size: .75rem; color: var(--v-text2);
}
.v-card-avatar {
    width: 20px; height: 20px; border-radius: 50%;
    background: var(--v-bg3); overflow: hidden;
    display: flex; align-items: center; justify-content: center;
    font-size: .55rem; font-weight: 700; flex-shrink: 0;
}

/* ── PAGE HEADER / TABS / CHIPS ───────────────────── */
.v-page-title { font-size: 1.3rem; font-weight: 800; color: var(--v-text); }
.v-page-sub   { font-size: .85rem; color: var(--v-text2); }

.v-tabs { border-bottom: 1px solid var(--v-border); }
.v-tabs .nav-link {
    color: var(--v-text2); font-size: .88rem; font-weight: 600;
    border: none; border-bottom: 2px solid transparent;
    border-radius: 0; padding: 8px 16px; margin-bottom: -1px;
    background: none; transition: color .2s, border-color .2s;
}
.v-tabs .nav-link:hover { color: var(--v-text); }
.v-tabs .nav-link.active { color: var(--v-accent); border-bottom-color: var(--v-accent); }

.v-chip {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 5px 14px; border-radius: 50px;
    font-size: .82rem; font-weight: 600;
    background: var(--v-bg3); border: 1px solid var(--v-border);
    color: var(--v-text2); cursor: pointer;
    transition: color .15s, border-color .15s, background .15s;
    text-decoration: none;
}
.v-chip:hover, .v-chip.active {
    color: var(--v-accent); border-color: var(--v-accent);
    background: rgba(252, 81, 0, .08);
}

/* ── SECTION HEADER ───────────────────────────────── */
.v-section-title { font-size: 1.05rem; font-weight: 800; color: var(--v-text); }
.v-see-all { font-size: .82rem; font-weight: 600; color: var(--v-accent); }
.v-see-all:hover { text-decoration: underline; color: var(--v-accent); }

/* ── HERO BANNER (hashtag / category) ────────────── */
.v-hero-banner {
    background: linear-gradient(135deg, rgba(252,81,0,.12), rgba(252,81,0,.04));
    border: 1px solid rgba(252,81,0,.2);
    border-radius: var(--v-radius);
}
.v-hero-icon {
    width: 56px; height: 56px;
    background: var(--v-accent); border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.5rem; flex-shrink: 0;
}
.v-stat-val   { font-size: 1.1rem; font-weight: 800; color: var(--v-text); }
.v-stat-label { font-size: .72rem; color: var(--v-text2); }

/* ── TRENDING LIST ────────────────────────────────── */
.v-trending-item {
    background: var(--v-bg2);
    border: 1px solid var(--v-border);
    border-radius: var(--v-radius);
    transition: border-color .2s;
    color: var(--v-text);
    display: flex; align-items: center;
}
.v-trending-item:hover { border-color: var(--v-accent); color: var(--v-text); }
.v-rank { font-size: 1.3rem; font-weight: 800; color: var(--v-text3); min-width: 32px; text-align: center; }
.v-rank.top3 { color: var(--v-accent); }
.v-trending-thumb {
    width: 56px; height: 76px; border-radius: 6px;
    background: var(--v-bg3); overflow: hidden; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center; color: var(--v-text3);
}
.v-trending-badge {
    background: rgba(252,81,0,.15); color: var(--v-accent);
    font-size: .68rem; font-weight: 700;
    padding: 2px 8px; border-radius: 50px; white-space: nowrap;
}

/* ── DETAIL PAGE ──────────────────────────────────── */
.v-player {
    background: #000; border-radius: var(--v-radius);
    aspect-ratio: 9/16; max-height: 75vh;
    overflow: hidden;
    display: flex; align-items: center; justify-content: center;
}
.v-player video { width: 100%; height: 100%; object-fit: contain; }
.v-player-placeholder { text-align: center; cursor: pointer; }
.v-player-btn {
    width: 72px; height: 72px;
    background: rgba(252,81,0,.2); border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 12px;
    transition: background .2s;
}
.v-player-btn:hover { background: rgba(252,81,0,.4); }

.v-avatar-sm { width: 42px; height: 42px; border-radius: 50%; background: var(--v-bg3); overflow: hidden; flex-shrink: 0; display: flex; align-items: center; justify-content: center; color: var(--v-text2); font-size: .75rem; font-weight: 700; }
.v-avatar-xs { width: 32px; height: 32px; border-radius: 50%; background: var(--v-bg3); overflow: hidden; flex-shrink: 0; display: flex; align-items: center; justify-content: center; color: var(--v-text2); font-size: .65rem; font-weight: 700; }

.v-stat-btn {
    display: inline-flex; align-items: center; gap: 5px;
    color: var(--v-text2); font-size: .85rem; cursor: pointer;
    background: none; border: none; padding: 0;
    transition: color .15s;
}
.v-stat-btn:hover { color: var(--v-accent); }

.v-tag-pill {
    color: var(--v-accent); font-size: .8rem; font-weight: 500;
    background: rgba(252,81,0,.1); padding: 3px 10px; border-radius: 50px;
}

.v-related-card {
    display: flex; gap: 10px;
    background: var(--v-bg2); border: 1px solid var(--v-border);
    border-radius: var(--v-radius); padding: 10px;
    color: var(--v-text); transition: border-color .2s;
}
.v-related-card:hover { border-color: var(--v-accent); color: var(--v-text); }
.v-related-thumb {
    width: 80px; height: 107px; border-radius: 6px;
    background: var(--v-bg3); flex-shrink: 0;
    display: flex; align-items: center; justify-content: center; color: var(--v-text3);
}

/* ── EXPLORE GRID ─────────────────────────────────── */
.v-cat-card {
    background: var(--v-bg2); border: 1px solid var(--v-border);
    border-radius: var(--v-radius); padding: 20px 16px;
    text-align: center; cursor: pointer; color: var(--v-text);
    transition: border-color .2s, transform .2s;
    display: block;
}
.v-cat-card:hover {
    border-color: var(--v-accent); transform: translateY(-2px); color: var(--v-text);
}
.v-cat-icon {
    width: 48px; height: 48px; border-radius: 12px;
    background: rgba(252, 81, 0, .12);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.4rem; margin: 0 auto 10px;
}

/* ── SEARCH HERO ──────────────────────────────────── */
.v-search-hero { padding: 32px 0 24px; text-align: center; }
.v-search-big {
    max-width: 560px; margin: 0 auto;
    display: flex; align-items: center;
    background: var(--v-bg3); border: 1px solid var(--v-border);
    border-radius: 50px; padding: 0 6px 0 20px; height: 50px;
    transition: border-color .2s;
}
.v-search-big:focus-within { border-color: var(--v-accent); }
.v-search-big input { flex: 1; background: none; border: none; outline: none; color: var(--v-text); font-size: .95rem; }
.v-search-big input::placeholder { color: var(--v-text3); }

/* ── UPLOAD DROPZONE ──────────────────────────────── */
.v-dropzone {
    border: 2px dashed var(--v-border); border-radius: var(--v-radius);
    padding: 40px 20px; text-align: center; cursor: pointer;
    transition: border-color .2s;
}
.v-dropzone:hover { border-color: var(--v-accent); }
.v-dropzone-icon {
    width: 56px; height: 56px;
    background: rgba(252,81,0,.12); border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    color: var(--v-accent); margin: 0 auto 14px;
}

/* ── FORM CONTROLS ────────────────────────────────── */
.v-form-control {
    background: var(--v-bg3) !important;
    border: 1px solid var(--v-border) !important;
    color: var(--v-text) !important;
    border-radius: 8px !important;
}
.v-form-control:focus {
    border-color: var(--v-accent) !important;
    box-shadow: 0 0 0 3px rgba(252,81,0,.15) !important;
    background: var(--v-bg3) !important;
    color: var(--v-text) !important;
}
.v-form-control::placeholder { color: var(--v-text3) !important; }
.v-form-label { font-size: .85rem; font-weight: 600; color: var(--v-text2); }
select.v-form-control option { background: var(--v-bg3); color: var(--v-text); }

/* ── FEATURED BANNER ──────────────────────────────── */
.v-featured-banner {
    background: linear-gradient(135deg, rgba(252,81,0,.12), rgba(252,81,0,.04));
    border: 1px solid rgba(252,81,0,.2);
    border-radius: var(--v-radius);
}
.v-featured-thumb {
    width: 120px; flex-shrink: 0;
    aspect-ratio: 3/4; border-radius: 8px;
    background: var(--v-bg3); overflow: hidden;
    display: flex; align-items: center; justify-content: center; color: var(--v-text3);
    position: relative;
}

/* ── BOTTOM NAV (mobile) ──────────────────────────── */
.v-bottom-nav {
    display: none; position: fixed; bottom: 0; left: 0; right: 0;
    height: 60px; background: var(--v-bg2);
    border-top: 1px solid var(--v-border); z-index: 1030;
}
.v-bottom-nav-inner { display: flex; height: 100%; }
.v-bottom-nav-item {
    flex: 1; display: flex; flex-direction: column;
    align-items: center; justify-content: center; gap: 2px;
    color: var(--v-text3); font-size: .62rem; font-weight: 600;
    transition: color .15s;
}
.v-bottom-nav-item.active { color: var(--v-accent); }
.v-bottom-nav-item .upload-icon {
    width: 36px; height: 36px; background: var(--v-accent);
    border-radius: 10px; display: flex; align-items: center; justify-content: center;
}

/* ── COMMENT ──────────────────────────────────────── */
.v-comment + .v-comment { border-top: 1px solid var(--v-border); padding-top: 14px; margin-top: 14px; }

/* ── EMPTY STATE ──────────────────────────────────── */
.v-empty { text-align: center; padding: 60px 20px; color: var(--v-text2); }
.v-empty svg { opacity: .35; }

/* ── RESPONSIVE ───────────────────────────────────── */
@media (max-width: 991.98px) {
    .v-sidebar { transform: translateX(-100%); }
    .v-sidebar.open { transform: translateX(0); box-shadow: 4px 0 24px rgba(0,0,0,.5); }
    .v-main { margin-left: 0; padding: 16px; }
}

@media (max-width: 767.98px) {
    .v-bottom-nav { display: block; }
    body { padding-bottom: 60px; }
    .v-search-wrap { max-width: none; }
    .btn-upload-label { display: none; }
}

@media (max-width: 575.98px) {
    .v-main { padding: 12px; }
}

/* =====================================================
   RIGHT SIDEBAR SECTIONS
   ===================================================== */

/* ── Common section wrapper ───────────────────────── */
.v-sidebar-section {
    background: var(--v-bg2);
    border: 1px solid var(--v-border);
    border-radius: var(--v-radius);
    overflow: hidden;
    margin-bottom: 14px;
}

.v-sidebar-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 14px 10px;
    border-bottom: 1px solid var(--v-border);
}

.v-sidebar-section-title {
    font-size: .85rem;
    font-weight: 800;
    color: var(--v-text);
    display: flex;
    align-items: center;
    gap: 5px;
}

.v-sidebar-viewall {
    font-size: .75rem;
    font-weight: 600;
    color: var(--v-accent);
    white-space: nowrap;
}
.v-sidebar-viewall:hover { color: var(--v-accent2); text-decoration: underline; }

.v-sidebar-section-footer {
    display: block;
    text-align: center;
    padding: 10px;
    font-size: .78rem;
    font-weight: 600;
    color: var(--v-accent);
    border-top: 1px solid var(--v-border);
    transition: background .15s;
}
.v-sidebar-section-footer:hover { background: rgba(252,81,0,.06); color: var(--v-accent); }

/* ── Top Downloads ────────────────────────────────── */
.v-top-downloads { padding: 6px 0; }

.v-top-dl-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 14px;
    color: var(--v-text);
    transition: background .15s;
    text-decoration: none;
}
.v-top-dl-item:hover { background: var(--v-bg3); color: var(--v-text); }

.v-top-dl-rank {
    font-size: 1rem;
    font-weight: 800;
    color: var(--v-text3);
    min-width: 18px;
    text-align: center;
    flex-shrink: 0;
}
.v-top-dl-rank.top { color: var(--v-accent); }

.v-top-dl-thumb {
    width: 44px;
    height: 44px;
    border-radius: 6px;
    background: var(--v-bg3);
    overflow: hidden;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--v-text3);
    font-size: 1.1rem;
}
.v-top-dl-thumb img { width: 100%; height: 100%; object-fit: cover; }

.v-top-dl-info { flex: 1; min-width: 0; }

.v-top-dl-title {
    font-size: .8rem;
    font-weight: 600;
    color: var(--v-text);
    line-height: 1.35;
    margin-bottom: 3px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.v-top-dl-count {
    font-size: .72rem;
    color: var(--v-text2);
    display: flex;
    align-items: center;
    gap: 4px;
}

/* ── Trending Countries ───────────────────────────── */
.v-country-list { padding: 4px 0; }

.v-country-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    font-size: .83rem;
    color: var(--v-text2);
    transition: background .15s;
}
.v-country-item:hover { background: var(--v-bg3); }

.v-country-flag { font-size: 1.1rem; flex-shrink: 0; }

.v-country-name { font-weight: 600; color: var(--v-text); flex: 1; }

.v-country-count {
    font-size: .75rem;
    color: var(--v-text2);
    white-space: nowrap;
}

/* ── Download CTA Banner ──────────────────────────── */
.v-cta-banner {
    background: linear-gradient(135deg, #1a0a00 0%, #0d0500 60%, #12060a 100%);
    border: 1px solid rgba(252,81,0,.25);
    border-radius: var(--v-radius);
    padding: 18px 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    overflow: hidden;
    position: relative;
    margin-bottom: 14px;
}

.v-cta-banner::before {
    content: '';
    position: absolute;
    top: -20px; right: -20px;
    width: 100px; height: 100px;
    background: radial-gradient(circle, rgba(252,81,0,.2), transparent 70%);
    pointer-events: none;
}

.v-cta-content { flex: 1; }

.v-cta-title {
    font-size: .9rem;
    font-weight: 800;
    color: var(--v-text);
    line-height: 1.35;
    margin-bottom: 5px;
}

.v-cta-desc {
    font-size: .78rem;
    color: var(--v-text2);
    line-height: 1.5;
    margin-bottom: 10px;
}

.v-cta-icon {
    font-size: 2.4rem;
    color: var(--v-accent);
    opacity: .7;
    flex-shrink: 0;
    line-height: 1;
}

/* ── Trending Keywords ────────────────────────────── */
.v-keyword-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
    padding: 12px 14px;
}

.v-keyword-chip {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 4px;
    padding: 6px 10px;
    background: var(--v-bg3);
    border: 1px solid var(--v-border);
    border-radius: 6px;
    font-size: .78rem;
    font-weight: 600;
    color: var(--v-text2);
    transition: color .15s, border-color .15s, background .15s;
    text-decoration: none;
}
.v-keyword-chip:hover {
    color: var(--v-accent);
    border-color: var(--v-accent);
    background: rgba(252,81,0,.06);
}
.v-keyword-chip i { font-size: .7rem; opacity: .6; flex-shrink: 0; }

/* ── Right sidebar layout ─────────────────────────── */
.v-right-sidebar {
    width: 280px;
    flex-shrink: 0;
}

@media (max-width: 1199.98px) {
    .v-right-sidebar { display: none; }
}

/* =====================================================
   FOOTER
   ===================================================== */

.v-footer {
    background: #090c11;
    border-top: 1px solid var(--v-border);
    /* full width — sidebar chỉ che nội dung, dùng padding-left để tránh */
    padding-left: var(--v-sidebar);
    margin-top: 40px;
}

.v-footer-inner {
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr 1fr 1.6fr;
    gap: 40px;
    padding: 44px 32px 36px;
    max-width: 1400px;
    margin: 0 auto;
}

/* ── Brand col ────────────────────────────────────── */
.v-footer-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    margin-bottom: 14px;
}

.v-footer-logo-icon {
    width: 38px; height: 38px;
    background: var(--v-accent);
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: 1.1rem;
    flex-shrink: 0;
}

.v-footer-logo-text {
    display: flex; flex-direction: column;
    line-height: 1.15;
}

.v-footer-logo-text span {
    font-size: .88rem;
    font-weight: 800;
    color: var(--v-text);
}

.v-footer-logo-text em {
    font-style: normal;
    font-size: .78rem;
    font-weight: 700;
    color: var(--v-accent);
}

.v-footer-tagline {
    font-size: .82rem;
    color: var(--v-text2);
    line-height: 1.65;
    margin-bottom: 18px;
}

.v-footer-socials {
    display: flex;
    gap: 8px;
}

.v-social-btn {
    width: 34px; height: 34px;
    background: var(--v-bg3);
    border: 1px solid var(--v-border);
    border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    color: var(--v-text2);
    font-size: .95rem;
    transition: color .15s, border-color .15s, background .15s;
    text-decoration: none;
}
.v-social-btn:hover {
    color: var(--v-accent);
    border-color: var(--v-accent);
    background: rgba(252,81,0,.08);
}

/* ── Nav cols ─────────────────────────────────────── */
.v-footer-col-title {
    font-size: .82rem;
    font-weight: 800;
    color: var(--v-text);
    text-transform: uppercase;
    letter-spacing: .06em;
    margin-bottom: 14px;
}

.v-footer-links {
    list-style: none;
    padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: 8px;
}

.v-footer-links a {
    font-size: .83rem;
    color: var(--v-text2);
    text-decoration: none;
    transition: color .15s;
    line-height: 1;
}
.v-footer-links a:hover { color: var(--v-accent); }

/* ── Newsletter col ───────────────────────────────── */
.v-footer-newsletter-desc {
    font-size: .82rem;
    color: var(--v-text2);
    line-height: 1.6;
    margin-bottom: 14px;
}

.v-newsletter-form {
    display: flex;
    gap: 0;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid var(--v-border);
    transition: border-color .2s;
}
.v-newsletter-form:focus-within { border-color: var(--v-accent); }

.v-newsletter-input {
    flex: 1;
    background: var(--v-bg3);
    border: none;
    outline: none;
    padding: 10px 14px;
    font-size: .83rem;
    color: var(--v-text);
    font-family: inherit;
    min-width: 0;
}
.v-newsletter-input::placeholder { color: var(--v-text3); }

.v-newsletter-btn {
    background: var(--v-accent);
    color: #fff;
    border: none;
    padding: 10px 16px;
    font-size: .83rem;
    font-weight: 700;
    font-family: inherit;
    cursor: pointer;
    white-space: nowrap;
    transition: background .2s;
}
.v-newsletter-btn:hover { background: var(--v-accent2); }

/* ── Bottom bar ───────────────────────────────────── */
.v-footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
    padding: 16px 32px;
    border-top: 1px solid var(--v-border);
    font-size: .78rem;
    color: var(--v-text3);
    max-width: 1400px;
    margin: 0 auto;
}
.v-footer-bottom strong { color: var(--v-text2); }
.v-footer-made { display: flex; align-items: center; gap: 4px; }

/* ── Responsive footer ────────────────────────────── */
@media (max-width: 1199.98px) {
    .v-footer { padding-left: 0; }
    .v-footer-inner {
        grid-template-columns: 1fr 1fr 1fr;
        gap: 28px;
    }
    .v-footer-brand { grid-column: 1 / -1; }
    .v-footer-newsletter { grid-column: span 3; }
}

@media (max-width: 767.98px) {
    .v-footer-inner {
        grid-template-columns: 1fr 1fr;
        padding: 28px 20px 24px;
    }
    .v-footer-brand     { grid-column: 1 / -1; }
    .v-footer-newsletter{ grid-column: 1 / -1; }
    .v-footer-bottom    { padding: 14px 20px; }
}

@media (max-width: 479.98px) {
    .v-footer-inner { grid-template-columns: 1fr; }
}

/* =====================================================
   TRENDING PAGE SECTIONS
   ===================================================== */

/* ── Trending Hero ────────────────────────────────── */
/* Hero carousel styles moved to trending-hero.blade.php @push('styles') */
.v-trending-hero {
    min-width: 0;
}

.v-trending-hero-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 14px;
}

.v-trending-hero-updated {
    font-size: .75rem;
    color: var(--v-text3);
    display: flex;
    align-items: center;
    gap: 5px;
}

/* Carousel wrapper: arrows + scrollable track */
.v-hero-carousel-wrap {
    position: relative;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Scrollable track */
.v-trending-hero-grid {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    scroll-behavior: smooth;
    scrollbar-width: none;       /* Firefox */
    -ms-overflow-style: none;    /* IE/Edge */
    flex: 1;
    min-width: 0;
}
.v-trending-hero-grid::-webkit-scrollbar { display: none; }

/* Each card: fixed width so partial next card peeks */
.v-hero-card {
    flex: 0 0 calc(20% - 10px);
    min-width: 160px;
    display: block;
    color: var(--v-text);
    text-decoration: none;
    border-radius: var(--v-radius);
    overflow: hidden;
    background: var(--v-bg2);
    border: 1px solid var(--v-border);
    transition: border-color .2s, transform .2s;
}
.v-hero-card:hover {
    border-color: var(--v-accent);
    transform: translateY(-3px);
    color: var(--v-text);
}

.v-hero-thumb {
    position: relative;
    aspect-ratio: 9/14;
    background: var(--v-bg3);
    overflow: hidden;
}

.v-hero-thumb-placeholder {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    color: var(--v-text3);
    font-size: 1.8rem;
}

.v-hero-play {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    background: rgba(0,0,0,.3);
    opacity: 0; transition: opacity .2s;
}
.v-hero-card:hover .v-hero-play { opacity: 1; }

.v-hero-play-btn {
    width: 40px; height: 40px;
    background: rgba(0,0,0,.65);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
}

.v-hero-rank {
    position: absolute; top: 8px; left: 8px;
    width: 26px; height: 26px;
    background: var(--v-bg);
    color: var(--v-text2);
    border-radius: 6px;
    font-size: .78rem; font-weight: 800;
    display: flex; align-items: center; justify-content: center;
}
.v-hero-rank.hot {
    background: var(--v-accent);
    color: #fff;
}

.v-hero-duration {
    position: absolute; bottom: 7px; right: 8px;
    background: rgba(0,0,0,.75);
    color: #fff; font-size: .68rem; font-weight: 700;
    padding: 2px 6px; border-radius: 4px;
}

.v-hero-info { padding: 10px 10px 12px; }

.v-hero-title {
    font-size: .8rem; font-weight: 600;
    color: var(--v-text); line-height: 1.4;
    margin-bottom: 4px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.v-hero-views {
    font-size: .72rem; color: var(--v-text2);
    margin-bottom: 5px;
}

.v-hero-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: .72rem; color: var(--v-text2);
}

.v-hero-growth {
    color: #22c55e; font-weight: 700;
    display: flex; align-items: center; gap: 1px;
}

/* Arrow buttons — always visible, outside the track */
.v-hero-arrow {
    flex-shrink: 0;
    width: 34px; height: 34px;
    background: var(--v-bg2);
    border: 1px solid var(--v-border);
    border-radius: 50%;
    color: var(--v-text2);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: color .15s, border-color .15s, background .15s, opacity .15s;
    font-size: .95rem;
    padding: 0;
}
.v-hero-arrow:hover:not(:disabled) {
    color: var(--v-accent);
    border-color: var(--v-accent);
    background: rgba(252,81,0,.08);
}
.v-hero-arrow:disabled {
    opacity: .3;
    cursor: not-allowed;
}

/* ── Rising Videos ────────────────────────────────── */
.v-rising-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.v-rising-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--v-bg2);
    border: 1px solid var(--v-border);
    border-radius: var(--v-radius);
    color: var(--v-text);
    text-decoration: none;
    transition: border-color .2s;
}
.v-rising-item:hover { border-color: var(--v-accent); color: var(--v-text); }

.v-rising-rank {
    font-size: .7rem; font-weight: 800;
    color: var(--v-text3);
    min-width: 20px; text-align: center;
    flex-shrink: 0;
}

.v-rising-thumb {
    width: 52px; height: 52px;
    border-radius: 6px;
    background: var(--v-bg3);
    flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    color: var(--v-text3); font-size: 1.1rem;
    position: relative; overflow: hidden;
}

.v-rising-duration {
    position: absolute; bottom: 2px; right: 3px;
    background: rgba(0,0,0,.75); color: #fff;
    font-size: .58rem; font-weight: 700;
    padding: 1px 4px; border-radius: 3px;
}

.v-rising-info { flex: 1; min-width: 0; }

.v-rising-title {
    font-size: .8rem; font-weight: 600;
    color: var(--v-text); line-height: 1.35;
    margin-bottom: 3px;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.v-rising-views {
    font-size: .72rem; color: var(--v-text2);
    margin-bottom: 3px;
}

.v-rising-meta {
    display: flex; align-items: center; gap: 8px;
    font-size: .72rem; color: var(--v-text2);
}

.v-rising-growth {
    color: #22c55e; font-weight: 700;
    display: flex; align-items: center; gap: 1px;
    margin-left: auto;
}

/* ── Trending by Category ─────────────────────────── */
.v-trendcat-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 10px;
}

.v-trendcat-card {
    display: block; text-align: center;
    border-radius: var(--v-radius);
    overflow: hidden;
    background: var(--v-bg2);
    border: 1px solid var(--v-border);
    color: var(--v-text);
    text-decoration: none;
    transition: border-color .2s, transform .2s;
}
.v-trendcat-card:hover {
    border-color: var(--v-accent);
    transform: translateY(-2px);
    color: var(--v-text);
}

.v-trendcat-thumb {
    aspect-ratio: 1/1;
    display: flex; align-items: center; justify-content: center;
    font-size: 2rem;
}

.v-trendcat-emoji { line-height: 1; }

.v-trendcat-name {
    font-size: .78rem; font-weight: 700;
    color: var(--v-text);
    padding: 6px 6px 2px;
}

.v-trendcat-count {
    font-size: .68rem; color: var(--v-text2);
    padding: 0 6px 8px;
}

/* ── Trending Hashtags (scroll) ───────────────────── */
.v-hashtag-scroll {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 10px;
}

.v-hashtag-card {
    display: block;
    border-radius: var(--v-radius);
    overflow: hidden;
    background: var(--v-bg2);
    border: 1px solid var(--v-border);
    color: var(--v-text);
    text-decoration: none;
    transition: border-color .2s, transform .2s;
}
.v-hashtag-card:hover {
    border-color: var(--v-accent);
    transform: translateY(-2px);
    color: var(--v-text);
}

.v-hashtag-thumb {
    aspect-ratio: 1/1;
    position: relative;
    display: flex; align-items: center; justify-content: center;
}

.v-hashtag-thumb-play {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
}
.v-hashtag-thumb-play i {
    width: 28px; height: 28px;
    background: rgba(0,0,0,.55);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: .9rem; color: #fff;
}

.v-hashtag-thumb-icon {
    position: absolute; bottom: 5px; left: 6px;
    font-size: 1rem; line-height: 1;
}

.v-hashtag-label {
    font-size: .78rem; font-weight: 700;
    color: var(--v-text);
    padding: 6px 8px 2px;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.v-hashtag-count {
    font-size: .68rem; color: var(--v-text2);
    padding: 0 8px 8px;
}

/* ── Responsive ───────────────────────────────────── */
@media (max-width: 1199.98px) {
    .v-hero-card { flex: 0 0 200px; }
}

@media (max-width: 991.98px) {
    .v-hero-card   { flex: 0 0 180px; }
    .v-trendcat-grid   { grid-template-columns: repeat(3, 1fr); }
    .v-hashtag-scroll  { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 767.98px) {
    .v-hero-card   { flex: 0 0 150px; }
    .v-rising-grid         { grid-template-columns: 1fr; }
    .v-trendcat-grid       { grid-template-columns: repeat(3, 1fr); }
    .v-hashtag-scroll      { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 575.98px) {
    .v-hero-card   { flex: 0 0 130px; }
    .v-trendcat-grid       { grid-template-columns: repeat(2, 1fr); }
    .v-hashtag-scroll      { grid-template-columns: repeat(2, 1fr); }
}

/* =====================================================
   SIDEBAR CATEGORIES SUBMENU
   ===================================================== */

/* Toggle button — same look as nav-link but full-width button */
.v-nav-submenu-toggle {
    text-align: left;
    background: none;
    border: none;
    cursor: pointer;
    font-size: .88rem;
    font-weight: 500;
    color: var(--v-text2);
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 18px;
    transition: color .15s, background .15s;
    position: relative;
}
.v-nav-submenu-toggle:hover { color: var(--v-text); background: var(--v-bg3); }
.v-nav-submenu-toggle.active {
    color: var(--v-accent);
    background: rgba(252, 81, 0, .08);
}
.v-nav-submenu-toggle.active::before {
    content: '';
    position: absolute; left: 0; top: 0; bottom: 0;
    width: 3px;
    background: var(--v-accent);
    border-radius: 0 3px 3px 0;
}

/* Chevron rotates when open */
.v-submenu-chevron {
    font-size: .75rem;
    transition: transform .25s ease;
    flex-shrink: 0;
}
.v-nav-submenu-toggle[aria-expanded="true"] .v-submenu-chevron {
    transform: rotate(180deg);
}

/* Submenu list — collapsed by default */
.v-submenu {
    max-height: 0;
    overflow: hidden;
    transition: max-height .3s ease;
    background: rgba(0, 0, 0, .15);
    border-left: 2px solid var(--v-border);
    margin-left: 18px;
}
.v-submenu.open {
    max-height: 600px; /* large enough for all items */
}

/* Submenu item */
.v-submenu-link {
    display: block;
    padding: 8px 16px;
    font-size: .84rem;
    font-weight: 500;
    color: var(--v-text2);
    text-decoration: none;
    transition: color .15s, background .15s, padding-left .15s;
    border-radius: 0 6px 6px 0;
}
.v-submenu-link:hover {
    color: var(--v-text);
    background: var(--v-bg3);
    padding-left: 20px;
}
.v-submenu-link.active {
    color: var(--v-accent);
    font-weight: 700;
    border-left: 2px solid var(--v-accent);
    margin-left: -2px;
    padding-left: 18px;
}

/* "More Categories" link */
.v-submenu-more {
    color: var(--v-accent);
    font-size: .8rem;
    opacity: .8;
}
.v-submenu-more:hover { opacity: 1; color: var(--v-accent); }

/* =====================================================
   SIDEBAR LEFT — REGION + CTA
   ===================================================== */

/* ── Region list ──────────────────────────────────── */
.v-region-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 18px;
    font-size: .85rem;
    font-weight: 500;
    color: var(--v-text2);
    text-decoration: none;
    transition: color .15s, background .15s;
    border-radius: 0;
    position: relative;
}
.v-region-item:hover {
    color: var(--v-text);
    background: var(--v-bg3);
}
.v-region-item.active {
    color: var(--v-accent);
    background: rgba(252, 81, 0, .08);
}
.v-region-item.active::before {
    content: '';
    position: absolute; left: 0; top: 0; bottom: 0;
    width: 3px;
    background: var(--v-accent);
    border-radius: 0 3px 3px 0;
}

/* Flag emoji */
.v-region-flag {
    font-size: 1.15rem;
    line-height: 1;
    width: 22px;
    text-align: center;
    flex-shrink: 0;
}

/* Icon for "All Regions" and "More" */
.v-region-icon {
    width: 22px; height: 22px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: .72rem;
    flex-shrink: 0;
}
.v-region-icon--all {
    background: var(--v-accent);
    color: #fff;
}
.v-region-icon--more {
    background: var(--v-bg3);
    border: 1px solid var(--v-border);
    color: var(--v-text2);
}
.v-region-item.active .v-region-icon--all {
    box-shadow: 0 0 0 2px rgba(252,81,0,.35);
}

.v-region-label {
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ── Sidebar CTA banner ───────────────────────────── */
.v-sidebar-cta {
    margin: 14px 12px 12px;
    background: linear-gradient(160deg, #1a0800 0%, #0d0500 55%, #120208 100%);
    border: 1px solid rgba(252, 81, 0, .22);
    border-radius: var(--v-radius);
    padding: 18px 14px 14px;
    position: relative;
    overflow: hidden;
}

/* Subtle glow top-right */
.v-sidebar-cta::before {
    content: '';
    position: absolute;
    top: -18px; right: -18px;
    width: 80px; height: 80px;
    background: radial-gradient(circle, rgba(252,81,0,.22), transparent 70%);
    pointer-events: none;
}

.v-sidebar-cta-body { position: relative; z-index: 1; }

.v-sidebar-cta-title {
    font-size: .88rem;
    font-weight: 800;
    color: var(--v-text);
    line-height: 1.35;
    margin-bottom: 7px;
}

.v-sidebar-cta-desc {
    font-size: .76rem;
    color: var(--v-text2);
    line-height: 1.55;
    margin-bottom: 12px;
}

.v-sidebar-cta-btn {
    display: block;
    width: 100%;
    text-align: center;
    background: var(--v-accent);
    color: #fff;
    font-size: .82rem;
    font-weight: 700;
    padding: 9px 12px;
    border-radius: 8px;
    text-decoration: none;
    transition: background .2s;
}
.v-sidebar-cta-btn:hover {
    background: var(--v-accent2);
    color: #fff;
}

/* Shopee bag icon bottom-center */
.v-sidebar-cta-icon {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    gap: 0;
    margin-top: 14px;
    position: relative;
    height: 52px;
}
.v-sidebar-cta-bag {
    font-size: 3rem;
    color: var(--v-accent);
    line-height: 1;
    display: block;
    filter: drop-shadow(0 4px 12px rgba(252,81,0,.4));
}
.v-sidebar-cta-arrow {
    position: absolute;
    bottom: 2px;
    right: calc(50% - 14px);
    font-size: .95rem;
    color: #fff;
    background: var(--v-accent);
    border-radius: 50%;
    padding: 1px;
}

/* =====================================================
   CATEGORY SHOW PAGE
   ===================================================== */

/* ── Breadcrumb ───────────────────────────────────── */
.v-breadcrumb { background: none; padding: 0; margin: 0; font-size: .8rem; }
.v-breadcrumb .breadcrumb-item a { color: var(--v-text2); }
.v-breadcrumb .breadcrumb-item a:hover { color: var(--v-accent); }
.v-breadcrumb .breadcrumb-item.active { color: var(--v-text); }
.v-breadcrumb .breadcrumb-item + .breadcrumb-item::before { color: var(--v-text3); }

/* ── Hero banner ──────────────────────────────────── */
.v-catshow-hero {
    display: flex;
    gap: 20px;
    align-items: flex-start;
}
.v-catshow-hero-thumb {
    width: 130px; flex-shrink: 0;
    aspect-ratio: 4/3;
    background: var(--v-bg3);
    border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    position: relative; overflow: hidden;
}
.v-catshow-hero-play {
    position: absolute; inset: 0;
    display: flex; align-items: flex-end; justify-content: flex-start;
    padding: 8px;
}
.v-catshow-hero-play i {
    width: 28px; height: 28px;
    background: rgba(0,0,0,.65); border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: .9rem;
}
.v-catshow-hero-title {
    font-size: 1.4rem; font-weight: 800; color: var(--v-text); margin-bottom: 6px;
}
.v-catshow-hero-desc {
    font-size: .83rem; color: var(--v-text2); line-height: 1.6; margin-bottom: 10px;
}
.v-catshow-hero-stats {
    display: flex; align-items: center; gap: 6px;
    font-size: .8rem; color: var(--v-text2); margin-bottom: 14px;
}
.v-catshow-hero-dot { color: var(--v-text3); }
.v-catshow-hero-actions { display: flex; gap: 8px; }

/* ── Filter bar ───────────────────────────────────── */
.v-filter-bar {
    display: flex; align-items: center; flex-wrap: wrap; gap: 8px;
}
.v-filter-select {
    position: relative; display: inline-flex; align-items: center;
}
.v-filter-dropdown {
    appearance: none; -webkit-appearance: none;
    background: var(--v-bg3);
    border: 1px solid var(--v-border);
    border-radius: 8px;
    color: var(--v-text2);
    font-size: .8rem; font-family: inherit;
    padding: 6px 28px 6px 12px;
    cursor: pointer; outline: none;
    transition: border-color .2s, color .2s;
}
.v-filter-dropdown:focus { border-color: var(--v-accent); color: var(--v-text); }
.v-filter-dropdown option { background: var(--v-bg3); }
.v-filter-chevron {
    position: absolute; right: 8px; pointer-events: none;
    font-size: .65rem; color: var(--v-text3);
}
.v-filter-sort { display: flex; align-items: center; gap: 6px; }

/* ── Pagination ───────────────────────────────────── */
.v-pagination .page-link {
    background: var(--v-bg2);
    border-color: var(--v-border);
    color: var(--v-text2);
    font-size: .83rem;
    transition: all .15s;
}
.v-pagination .page-link:hover { background: var(--v-bg3); color: var(--v-text); }
.v-pagination .page-item.active .page-link {
    background: var(--v-accent); border-color: var(--v-accent); color: #fff;
}
.v-pagination .page-item.disabled .page-link { opacity: .4; }

/* ── Popular subcategories scroll ─────────────────── */
.v-subcat-scroll {
    display: flex; gap: 10px; overflow-x: auto;
    scrollbar-width: none; padding-bottom: 4px;
    align-items: stretch;
}
.v-subcat-scroll::-webkit-scrollbar { display: none; }
.v-subcat-card {
    flex: 0 0 110px; border-radius: var(--v-radius);
    background: var(--v-bg2); border: 1px solid var(--v-border);
    overflow: hidden; text-align: center; cursor: pointer;
    color: var(--v-text); text-decoration: none;
    transition: border-color .2s, transform .2s;
}
.v-subcat-card:hover { border-color: var(--v-accent); transform: translateY(-2px); color: var(--v-text); }
.v-subcat-thumb {
    aspect-ratio: 16/9; background: var(--v-bg3);
    display: flex; align-items: center; justify-content: center;
}
.v-subcat-name { font-size: .78rem; font-weight: 700; padding: 5px 6px 2px; }
.v-subcat-count { font-size: .68rem; color: var(--v-text2); padding: 0 6px 7px; }
.v-subcat-arrow {
    flex-shrink: 0; width: 36px; height: 36px; align-self: center;
    background: var(--v-bg3); border: 1px solid var(--v-border);
    border-radius: 50%; color: var(--v-text2); font-size: .85rem;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; transition: color .15s, border-color .15s;
}
.v-subcat-arrow:hover { color: var(--v-accent); border-color: var(--v-accent); }

/* ── Category right sidebar ───────────────────────── */
.v-cat-sidebar-box {
    background: var(--v-bg2);
    border: 1px solid var(--v-border);
    border-radius: var(--v-radius);
    padding: 16px;
}
.v-cat-sidebar-box-title {
    font-size: .82rem; font-weight: 800; color: var(--v-text);
    margin-bottom: 12px;
}
.v-cat-sidebar-desc {
    font-size: .78rem; color: var(--v-text2); line-height: 1.6; margin-bottom: 12px;
}
.v-cat-sidebar-stats {
    display: flex; justify-content: space-between; gap: 4px;
    padding: 10px 0 0;
    border-top: 1px solid var(--v-border);
}
.v-cat-sidebar-stat {
    display: flex; flex-direction: column; align-items: center; gap: 3px;
    flex: 1; text-align: center;
}
.v-cat-sidebar-stat i { font-size: 1.1rem; color: var(--v-text2); }
.v-cat-sidebar-stat-val { font-size: .78rem; font-weight: 800; color: var(--v-text); }
.v-cat-sidebar-stat-label { font-size: .65rem; color: var(--v-text2); }

/* Tag rows */
.v-cat-sidebar-tag-row {
    display: flex; align-items: center; justify-content: space-between;
    padding: 6px 0;
    border-bottom: 1px solid var(--v-border);
    font-size: .82rem; text-decoration: none;
    transition: opacity .15s;
}
.v-cat-sidebar-tag-row:last-child { border-bottom: none; }
.v-cat-sidebar-tag-row:hover { opacity: .8; }

/* Subcategory rows */
.v-cat-sidebar-sub-row {
    display: flex; align-items: center; justify-content: space-between;
    padding: 6px 0; font-size: .82rem;
    border-bottom: 1px solid var(--v-border);
}
.v-cat-sidebar-sub-row:last-child { border-bottom: none; }
.v-cat-sidebar-sub-name { color: var(--v-text2); }

/* Country rows */
.v-cat-sidebar-country-row {
    display: flex; align-items: center; gap: 8px;
    padding: 6px 0; font-size: .82rem;
    border-bottom: 1px solid var(--v-border);
}
.v-cat-sidebar-country-row:last-child { border-bottom: none; }
.v-cat-sidebar-flag { font-size: 1.1rem; flex-shrink: 0; }
.v-cat-sidebar-country-name { flex: 1; color: var(--v-text2); font-weight: 500; }

/* Count badge */
.v-cat-sidebar-count { font-size: .75rem; color: var(--v-text3); white-space: nowrap; }

/* View all link */
.v-cat-sidebar-viewall {
    font-size: .78rem; font-weight: 600; color: var(--v-accent);
    text-decoration: none;
}
.v-cat-sidebar-viewall:hover { text-decoration: underline; color: var(--v-accent); }

/* Trending mini videos */
.v-cat-sidebar-video {
    display: flex; gap: 10px; align-items: flex-start;
    text-decoration: none; color: var(--v-text);
    transition: opacity .15s;
}
.v-cat-sidebar-video:hover { opacity: .8; color: var(--v-text); }
.v-cat-sidebar-video-thumb {
    width: 64px; height: 64px; border-radius: 6px;
    background: var(--v-bg3); flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    color: var(--v-text3); font-size: 1.2rem;
}
.v-cat-sidebar-video-title {
    font-size: .78rem; font-weight: 600; line-height: 1.4;
    color: var(--v-text); margin-bottom: 3px;
    display: -webkit-box; -webkit-line-clamp: 2;
    -webkit-box-orient: vertical; overflow: hidden;
}
.v-cat-sidebar-video-views { font-size: .72rem; color: var(--v-text2); }

/* =====================================================
   EXPLORE PAGE
   ===================================================== */

/* ── Category circle pills ────────────────────────── */
.v-explore-cat-pills {
    display: flex;
    gap: 14px;
    overflow-x: auto;
    scrollbar-width: none;
    padding-bottom: 4px;
}
.v-explore-cat-pills::-webkit-scrollbar { display: none; }

.v-explore-cat-pill {
    display: flex; flex-direction: column;
    align-items: center; gap: 5px;
    text-decoration: none; flex-shrink: 0;
    color: var(--v-text2);
    transition: color .15s;
}
.v-explore-cat-pill:hover { color: var(--v-text); }
.v-explore-cat-pill.active { color: var(--v-text); }

.v-explore-cat-pill-icon {
    width: 52px; height: 52px;
    border-radius: 50%;
    background: var(--v-bg3);
    border: 2px solid var(--v-border);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.4rem;
    transition: border-color .15s, background .15s;
}
.v-explore-cat-pill.active .v-explore-cat-pill-icon {
    background: var(--v-accent);
    border-color: var(--v-accent);
    font-size: 1.1rem;
    color: #fff;
}
.v-explore-cat-pill.more .v-explore-cat-pill-icon {
    background: var(--v-bg3);
    border-color: var(--v-border);
    color: var(--v-text2);
}
.v-explore-cat-pill:hover .v-explore-cat-pill-icon {
    border-color: var(--v-accent);
}

.v-explore-cat-pill-label {
    font-size: .72rem; font-weight: 600;
    white-space: nowrap;
}

/* ── Toolbar ──────────────────────────────────────── */
.v-explore-toolbar {
    display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.v-explore-view-toggle {
    display: flex; gap: 2px;
    background: var(--v-bg3);
    border: 1px solid var(--v-border);
    border-radius: 8px; padding: 3px;
}
.v-view-btn {
    background: none; border: none; border-radius: 6px;
    padding: 5px 10px; font-size: .78rem; font-weight: 600;
    color: var(--v-text2); cursor: pointer;
    display: flex; align-items: center; gap: 4px;
    transition: color .15s, background .15s;
}
.v-view-btn.active { background: var(--v-bg2); color: var(--v-text); }
.v-view-btn:hover:not(.active) { color: var(--v-text); }

/* ── Video card extras for explore ───────────────── */
.v-explore-new-badge {
    position: absolute; top: 7px; left: 8px;
    background: var(--v-accent); color: #fff;
    font-size: .62rem; font-weight: 700;
    padding: 2px 7px; border-radius: 4px;
}
.v-card-more-btn {
    position: absolute; bottom: 7px; right: 8px;
    width: 22px; height: 22px;
    background: rgba(0,0,0,.55);
    border: none; border-radius: 4px;
    color: #fff; font-size: .7rem;
    display: flex; align-items: center; justify-content: center;
    opacity: 0; transition: opacity .15s;
    cursor: pointer;
}
.v-card:hover .v-card-more-btn { opacity: 1; }

/* ── Load More button ─────────────────────────────── */
.v-load-more-btn {
    background: var(--v-bg2);
    border: 1px solid var(--v-border);
    border-radius: 10px;
    color: var(--v-text2);
    font-size: .85rem; font-weight: 600;
    padding: 10px 32px;
    cursor: pointer;
    transition: color .15s, border-color .15s, background .15s;
    display: inline-flex; align-items: center; gap: 6px;
}
.v-load-more-btn:hover {
    color: var(--v-accent);
    border-color: var(--v-accent);
    background: rgba(252,81,0,.05);
}

/* ── Filter sidebar ───────────────────────────────── */
.v-explore-filter {
    background: var(--v-bg2);
    border: 1px solid var(--v-border);
    border-radius: var(--v-radius);
    overflow: hidden;
}
.v-explore-filter-head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 12px 14px 10px;
    border-bottom: 1px solid var(--v-border);
}
.v-explore-filter-title {
    font-size: .85rem; font-weight: 800; color: var(--v-text);
}
.v-explore-filter-clear {
    font-size: .75rem; font-weight: 600;
    color: var(--v-accent); background: none; border: none; cursor: pointer;
    padding: 0;
}
.v-explore-filter-clear:hover { text-decoration: underline; }

.v-filter-section { padding: 12px 14px; }
.v-filter-section-label {
    font-size: .75rem; font-weight: 700;
    color: var(--v-text2); text-transform: uppercase;
    letter-spacing: .05em; margin-bottom: 8px; display: block;
}
.v-filter-divider { height: 1px; background: var(--v-border); }

/* Duration buttons */
.v-duration-btns { display: flex; flex-wrap: wrap; gap: 5px; }
.v-duration-btn {
    background: var(--v-bg3);
    border: 1px solid var(--v-border);
    border-radius: 6px;
    color: var(--v-text2);
    font-size: .72rem; font-weight: 600;
    padding: 4px 8px; cursor: pointer;
    transition: all .15s;
}
.v-duration-btn.active {
    background: var(--v-accent); border-color: var(--v-accent);
    color: #fff;
}
.v-duration-btn:hover:not(.active) {
    border-color: var(--v-accent); color: var(--v-accent);
}

/* Radio list */
.v-filter-radio-list { display: flex; flex-direction: column; gap: 0; }
.v-filter-radio-item {
    display: flex; align-items: center; justify-content: space-between;
    padding: 7px 0;
    font-size: .82rem; color: var(--v-text2);
    border-bottom: 1px solid rgba(255,255,255,.04);
    cursor: pointer; transition: color .15s;
}
.v-filter-radio-item:last-child { border-bottom: none; }
.v-filter-radio-item.active { color: var(--v-text); font-weight: 600; }
.v-filter-radio-item:hover { color: var(--v-text); }

/* Trending tag rows in filter */
.v-filter-tag-row {
    display: flex; align-items: center; justify-content: space-between;
    padding: 5px 0;
    font-size: .78rem; text-decoration: none;
    border-bottom: 1px solid rgba(255,255,255,.04);
    transition: opacity .15s;
}
.v-filter-tag-row:last-child { border-bottom: none; }
.v-filter-tag-row:hover { opacity: .8; }

/* JS: duration + sort + source toggle */
.v-duration-btn,
.v-filter-radio-item { user-select: none; }

/* =====================================================
   VIDEO DETAIL PAGE
   ===================================================== */

/* ── Two-column layout ────────────────────────────── */
.v-detail-wrap {
    display: grid;
    grid-template-columns: 360px 1fr;
    gap: 24px;
    align-items: start;
}

/* Player column — fixed width, sticky */
.v-detail-player-col {
    min-width: 0;
    position: sticky;
    top: calc(var(--v-header) + 12px);
}

/* Right sidebar — scrollable info */
.v-detail-sidebar {
    min-width: 0;
}

/* ── Player box ───────────────────────────────────── */
.v-detail-player-box {
    overflow: hidden;
}

.v-detail-video {
    position: relative;
    display: flex;
    flex-direction: column;
}

.v-detail-video-inner {
    position: relative;
    aspect-ratio: 9/16;
    background: linear-gradient(180deg, #1a0f0f 0%, #0a0808 100%);
    overflow: hidden;
}

.v-detail-video-placeholder {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(160deg, #2a1810 0%, #0d0808 100%);
}

/* Play overlay */
.v-detail-play-overlay {
    position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    background: none; border: none; cursor: pointer;
    z-index: 3;
}
.v-detail-play-circle {
    width: 60px; height: 60px;
    background: rgba(0,0,0,.55);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: 1.4rem;
    transition: background .2s;
}
.v-detail-play-overlay:hover .v-detail-play-circle { background: rgba(252,81,0,.7); }

/* Top overlay: creator */
.v-detail-overlay-top {
    position: absolute; top: 0; left: 0; right: 0;
    display: flex; align-items: center; gap: 10px;
    padding: 14px 12px;
    background: linear-gradient(to bottom, rgba(0,0,0,.65) 0%, transparent 100%);
    z-index: 4;
}
.v-detail-creator { display: flex; align-items: center; gap: 8px; }
.v-detail-creator-avatar {
    width: 36px; height: 36px; border-radius: 50%;
    background: var(--v-bg3); border: 2px solid rgba(255,255,255,.3);
    display: flex; align-items: center; justify-content: center;
    color: var(--v-text2); font-size: .9rem; flex-shrink: 0;
    overflow: hidden;
}
.v-detail-creator-name {
    font-size: .82rem; font-weight: 700; color: #fff;
    display: flex; align-items: center; gap: 4px;
}
.v-detail-creator-followers { font-size: .68rem; color: rgba(255,255,255,.6); }

.v-detail-follow-btn {
    background: var(--v-accent); color: #fff; border: none;
    border-radius: 6px; padding: 4px 12px;
    font-size: .75rem; font-weight: 700; cursor: pointer;
    transition: background .2s;
}
.v-detail-follow-btn:hover { background: var(--v-accent2); }

.v-detail-more-btn {
    background: rgba(0,0,0,.4); border: none;
    width: 28px; height: 28px; border-radius: 50%;
    color: #fff; font-size: .85rem;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
}

/* Bottom overlay: title, caption, tags, music */
.v-detail-overlay-bottom {
    position: absolute;
    bottom: 48px;
    left: 6px;
    right: 52px;
    padding: 12px 12px 10px;
    z-index: 4;
}
.v-detail-video-title {
    font-size: .9rem; font-weight: 800; color: #fff;
    line-height: 1.35; margin-bottom: 4px;
}
.v-detail-video-caption {
    font-size: .75rem; color: rgba(255,255,255,.8);
    line-height: 1.4; margin-bottom: 5px;
}
.v-detail-video-tags { display: flex; flex-wrap: wrap; gap: 3px; margin-bottom: 5px; }
.v-detail-htag {
    font-size: .72rem; font-weight: 600; color: #fff;
    text-decoration: none; opacity: .9;
}
.v-detail-htag:hover { color: var(--v-accent2); opacity: 1; }
.v-detail-video-music {
    font-size: .72rem; color: rgba(255,255,255,.7);
    display: flex; align-items: center; gap: 4px;
}

/* Right action bar */
.v-detail-action-bar {
    position: absolute;
    right: -4px;
    bottom: 75px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    padding: 0 8px;
    z-index: 4;
}
.v-detail-action-btn {
    display: flex; flex-direction: column; align-items: center; gap: 2px;
    background: none; border: none; color: #fff; cursor: pointer;
    font-size: .6rem; font-weight: 700;
    transition: color .15s;
}
.v-detail-action-btn i { font-size: 1.4rem; filter: drop-shadow(0 1px 3px rgba(0,0,0,.6)); }
.v-detail-action-btn:hover { color: var(--v-accent); }

/* Progress bar */
.v-detail-progress-bar {
    height: 3px; background: rgba(255,255,255,.25);
    position: relative; cursor: pointer;
}
.v-detail-progress-fill {
    height: 100%; background: var(--v-accent);
    border-radius: 2px;
}
.v-detail-progress-thumb {
    position: absolute; top: 50%; transform: translate(-50%, -50%);
    width: 10px; height: 10px;
    background: #fff; border-radius: 50%;
}

/* Controls bar */
.v-detail-controls {
    display: flex; align-items: center; gap: 8px;
    padding: 8px 10px;
    background: #0d0808;
}
.v-detail-ctrl-btn {
    background: none; border: none; color: var(--v-text2);
    font-size: .85rem; cursor: pointer; padding: 2px 4px;
    transition: color .15s;
    display: flex; align-items: center;
}
.v-detail-ctrl-btn:hover { color: #fff; }
.v-detail-ctrl-time { font-size: .72rem; color: var(--v-text2); white-space: nowrap; }
.v-detail-speed-btn {
    font-size: .72rem; font-weight: 600; padding: 2px 6px;
    border: 1px solid var(--v-border); border-radius: 4px;
}

/* ── Description / Comments tabs ──────────────────── */
.v-detail-tabs { border-bottom: 1px solid var(--v-border); }
.v-detail-tabs .nav-link {
    color: var(--v-text2); font-size: .88rem; font-weight: 600;
    border: none; border-bottom: 2px solid transparent;
    border-radius: 0; padding: 8px 16px; margin-bottom: -1px;
    background: none; transition: color .2s, border-color .2s; cursor: pointer;
}
.v-detail-tabs .nav-link:hover { color: var(--v-text); }
.v-detail-tabs .nav-link.active { color: var(--v-accent); border-bottom-color: var(--v-accent); }

.v-detail-desc-text {
    font-size: .83rem; color: var(--v-text2); line-height: 1.7;
}

.v-detail-showmore {
    background: none; border: none; color: var(--v-accent);
    font-size: .78rem; font-weight: 600; cursor: pointer; padding: 0;
    display: flex; align-items: center; gap: 4px;
}
.v-detail-showmore:hover { text-decoration: underline; }

.v-detail-comment {
    display: flex; gap: 10px;
}
.v-detail-comment-avatar {
    width: 32px; height: 32px; border-radius: 50%;
    background: var(--v-bg3); flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    font-size: .65rem; font-weight: 700; color: var(--v-text2);
}
.v-detail-comment-name { font-size: .78rem; font-weight: 700; color: var(--v-text); margin-bottom: 2px; }
.v-detail-comment-text { font-size: .78rem; color: var(--v-text2); line-height: 1.5; }
.v-detail-comment-time { font-size: .68rem; color: var(--v-text3); margin-top: 2px; }

/* ── More Like This scroll ────────────────────────── */
.v-morelike-scroll {
    display: flex; gap: 10px; overflow-x: auto;
    scrollbar-width: none; padding-bottom: 4px;
}
.v-morelike-scroll::-webkit-scrollbar { display: none; }

.v-morelike-card {
    flex: 0 0 100px; text-decoration: none; color: var(--v-text);
    transition: opacity .15s;
}
.v-morelike-card:hover { opacity: .8; color: var(--v-text); }
.v-morelike-thumb {
    aspect-ratio: 9/14; background: var(--v-bg3);
    border-radius: 8px; overflow: hidden; margin-bottom: 6px;
    position: relative;
    display: flex; align-items: center; justify-content: center;
}
.v-morelike-title {
    font-size: .72rem; font-weight: 600; line-height: 1.35;
    margin-bottom: 2px;
    display: -webkit-box; -webkit-line-clamp: 2;
    -webkit-box-orient: vertical; overflow: hidden;
}
.v-morelike-views { font-size: .65rem; color: var(--v-text2); }

/* ── Right info panel ─────────────────────────────── */
.v-detail-right { min-width: 0; }

.v-detail-rank-badge {
    font-size: .78rem; font-weight: 700; color: var(--v-accent);
    display: flex; align-items: center; gap: 5px;
}

.v-detail-info-title {
    font-size: 1.3rem; font-weight: 800; color: var(--v-text);
    line-height: 1.3;
}

.v-detail-info-meta {
    display: flex; align-items: center; gap: 8px;
    font-size: .78rem;
}

.v-detail-info-desc {}

.v-detail-dl-btn {
    display: flex; align-items: center; justify-content: center; gap: 8px;
    width: 100%; padding: 11px;
    background: var(--v-accent); color: #fff;
    border-radius: 8px; font-size: .88rem; font-weight: 700;
    text-decoration: none; transition: background .2s;
    margin-bottom: 8px;
}
.v-detail-dl-btn:hover { background: var(--v-accent2); color: #fff; }

.v-detail-copy-btn {
    display: flex; align-items: center; justify-content: center; gap: 8px;
    width: 100%; padding: 10px;
    background: var(--v-bg3); color: var(--v-text2);
    border: 1px solid var(--v-border); border-radius: 8px;
    font-size: .88rem; font-weight: 600; cursor: pointer;
    transition: all .15s;
}
.v-detail-copy-btn:hover { border-color: var(--v-accent); color: var(--v-accent); }

/* Share buttons */
.v-detail-share-btn {
    width: 38px; height: 38px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.05rem; text-decoration: none; cursor: pointer;
    border: none; transition: opacity .15s;
}
.v-detail-share-btn:hover { opacity: .8; }
.v-detail-share-btn.whatsapp  { background: #25d366; color: #fff; }
.v-detail-share-btn.facebook  { background: #1877f2; color: #fff; }
.v-detail-share-btn.twitter   { background: #000; color: #fff; }
.v-detail-share-btn.pinterest { background: #e60023; color: #fff; }
.v-detail-share-btn.link      { background: var(--v-bg3); color: var(--v-text2); border: 1px solid var(--v-border); }

/* Copy caption / hashtags */
.v-detail-copy-actions { display: flex; flex-direction: column; gap: 6px; }
.v-detail-copy-action-btn {
    display: flex; align-items: center; justify-content: space-between;
    padding: 9px 14px;
    background: var(--v-bg3); border: 1px solid var(--v-border);
    border-radius: 8px; color: var(--v-text2);
    font-size: .83rem; cursor: pointer;
    transition: color .15s, border-color .15s;
}
.v-detail-copy-action-btn:hover { color: var(--v-text); border-color: var(--v-accent); }

/* Product card */
.v-detail-product-label {
    font-size: .8rem; font-weight: 800; color: var(--v-text);
    margin-bottom: 8px;
}
.v-detail-product-card {
    display: flex; align-items: center; gap: 10px;
    background: var(--v-bg2); border: 1px solid var(--v-border);
    border-radius: 8px; padding: 10px 12px; margin-bottom: 0;
}
.v-detail-product-thumb {
    width: 48px; height: 48px; border-radius: 8px;
    background: var(--v-bg3); flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
}
.v-detail-product-name {
    font-size: .8rem; font-weight: 600; color: var(--v-text);
    line-height: 1.35; margin-bottom: 3px;
}
.v-detail-product-price { font-size: .88rem; font-weight: 800; color: var(--v-accent); }
.v-detail-product-shopee {
    width: 28px; height: 28px; background: var(--v-accent);
    border-radius: 6px; display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: .8rem; flex-shrink: 0;
}
.v-detail-product-cta {
    display: block; width: 100%; text-align: center;
    padding: 9px; margin-top: 8px;
    background: none; border: 1px solid var(--v-accent);
    border-radius: 8px; color: var(--v-accent);
    font-size: .83rem; font-weight: 700; text-decoration: none;
    transition: background .15s, color .15s;
}
.v-detail-product-cta:hover { background: var(--v-accent); color: #fff; }

/* Related video cards */
.v-related-card {
    display: flex; gap: 10px;
    color: var(--v-text); text-decoration: none;
    transition: opacity .15s;
}
.v-related-card:hover { opacity: .8; color: var(--v-text); }
.v-related-thumb {
    width: 80px; height: 60px; border-radius: 6px;
    background: var(--v-bg3); flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    color: var(--v-text3); position: relative; overflow: hidden;
}
.v-related-title {
    font-size: .8rem; font-weight: 600; line-height: 1.35;
    margin-bottom: 3px;
    display: -webkit-box; -webkit-line-clamp: 2;
    -webkit-box-orient: vertical; overflow: hidden;
}
.v-related-views { font-size: .72rem; color: var(--v-text2); }

/* ── Responsive ───────────────────────────────────── */
@media (max-width: 1199.98px) {
    .v-detail-wrap { grid-template-columns: 300px 1fr; gap: 16px; }
    .v-detail-player-col { position: static; }
}
@media (max-width: 767.98px) {
    .v-detail-wrap { grid-template-columns: 1fr; }
}

/* =====================================================
   HEADER — LANG + AVATAR DROPDOWNS
   ===================================================== */

/* ── Common dropdown wrapper ──────────────────────── */
.v-hdr-dropdown { position: relative; }

.v-hdr-dropdown-menu {
    position: absolute; top: calc(100% + 10px); left: 0;
    min-width: 200px;
    background: var(--v-bg2);
    border: 1px solid var(--v-border);
    border-radius: var(--v-radius);
    box-shadow: 0 8px 32px rgba(0,0,0,.45);
    z-index: 1050;
    padding: 6px 0;
    opacity: 0; visibility: hidden;
    transform: translateY(-6px);
    transition: opacity .18s ease, transform .18s ease, visibility .18s;
}
.v-hdr-dropdown-menu.open {
    opacity: 1; visibility: visible; transform: translateY(0);
}
.v-hdr-dropdown-menu--right { left: auto; right: 0; }

.v-hdr-dropdown-title {
    font-size: .68rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: .07em; color: var(--v-text3);
    padding: 6px 14px 4px;
}

.v-hdr-dropdown-divider { height: 1px; background: var(--v-border); margin: 4px 0; }

.v-hdr-dropdown-item {
    display: flex; align-items: center; gap: 10px;
    width: 100%; padding: 8px 14px;
    font-size: .83rem; font-weight: 500;
    color: var(--v-text2); background: none; border: none;
    text-decoration: none; cursor: pointer;
    transition: color .15s, background .15s;
    text-align: left;
}
.v-hdr-dropdown-item:hover { color: var(--v-text); background: var(--v-bg3); }
.v-hdr-dropdown-item.active { color: var(--v-text); font-weight: 600; }
.v-hdr-dropdown-item--danger { color: #ef4444; }
.v-hdr-dropdown-item--danger:hover { color: #ff6060; background: rgba(239,68,68,.08); }

/* ── Lang button ──────────────────────────────────── */
.v-hdr-lang-btn {
    display: flex; align-items: center; gap: 6px;
    background: none; border: none; cursor: pointer;
    color: var(--v-text2); padding: 5px 8px; border-radius: 8px;
    font-size: .85rem; font-weight: 600;
    transition: color .15s, background .15s;
}
.v-hdr-lang-btn:hover { color: var(--v-text); background: var(--v-bg3); }
.v-hdr-lang-btn[aria-expanded="true"] { color: var(--v-text); background: var(--v-bg3); }

.v-hdr-lang-label { font-size: .82rem; font-weight: 700; letter-spacing: .03em; }

.v-hdr-chevron {
    font-size: .65rem; color: var(--v-text3);
    transition: transform .2s ease;
}

.v-hdr-lang-flag { font-size: 1.1rem; line-height: 1; }

/* ── Avatar button ────────────────────────────────── */
.v-hdr-avatar-btn {
    width: 34px; height: 34px;
    border-radius: 50%;
    background: var(--v-bg3);
    border: 2px solid var(--v-border);
    color: var(--v-text2); font-size: 1.05rem;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: border-color .15s, color .15s;
}
.v-hdr-avatar-btn:hover { border-color: var(--v-accent); color: var(--v-text); }
.v-hdr-avatar-btn[aria-expanded="true"] { border-color: var(--v-accent); color: var(--v-text); }

/* Avatar info row at top of menu */
.v-hdr-avatar-info {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 14px 8px;
}
.v-hdr-avatar-preview {
    width: 36px; height: 36px; border-radius: 50%;
    background: var(--v-bg3); border: 1px solid var(--v-border);
    display: flex; align-items: center; justify-content: center;
    color: var(--v-text2); font-size: 1rem; flex-shrink: 0;
}
.v-hdr-avatar-name { font-size: .83rem; font-weight: 700; color: var(--v-text); }
.v-hdr-avatar-sub  { font-size: .72rem; color: var(--v-text3); }

/* =====================================================
   NEED HELP SECTION
   ===================================================== */

.v-need-help {
    background: var(--v-bg2);
    border: 1px solid var(--v-border);
    border-radius: var(--v-radius);
    padding: 20px 18px;
}

.v-need-help-title {
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--v-accent);
    margin-bottom: 6px;
}

.v-need-help-desc {
    font-size: .83rem;
    color: var(--v-text2);
    line-height: 1.5;
    margin-bottom: 18px;
}

.v-need-help-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
    margin-bottom: 20px;
}

.v-need-help-item {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    text-decoration: none;
    color: var(--v-text);
    transition: opacity .15s;
}
.v-need-help-item:hover { opacity: .8; color: var(--v-text); }

.v-need-help-icon {
    width: 42px; height: 42px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.1rem;
    flex-shrink: 0;
}
.v-need-help-icon.telegram  { background: #2AABEE; color: #fff; }
.v-need-help-icon.email     { background: #3a3f47; color: var(--v-text2); }
.v-need-help-icon.response  { background: #3a3f47; color: var(--v-text2); }

.v-need-help-label {
    font-size: .88rem;
    font-weight: 700;
    color: var(--v-text);
    margin-bottom: 2px;
}

.v-need-help-value {
    font-size: .78rem;
    color: var(--v-text2);
    line-height: 1.4;
}

.v-need-help-btn {
    display: block;
    width: 100%;
    text-align: center;
    background: var(--v-accent);
    color: #fff;
    font-size: .9rem;
    font-weight: 700;
    padding: 11px;
    border-radius: 8px;
    text-decoration: none;
    transition: background .2s;
}
.v-need-help-btn:hover { background: var(--v-accent2); color: #fff; }

/* =====================================================
   STATS BANNER
   ===================================================== */

.v-stats-banner {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2px;
    background: var(--v-border);
    border: 1px solid var(--v-border);
    border-radius: var(--v-radius);
    overflow: hidden;
    margin-bottom: 24px;
}

.v-stats-item {
    display: flex;
    align-items: center;
    gap: 14px;
    background: var(--v-bg2);
    padding: 16px 20px;
    transition: background .15s;
}
.v-stats-item:hover { background: var(--v-bg3); }

.v-stats-icon {
    width: 42px; height: 42px;
    border-radius: 50%;
    background: var(--v-accent);
    display: flex; align-items: center; justify-content: center;
    color: #fff;
    font-size: 1.05rem;
    flex-shrink: 0;
}

.v-stats-value {
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--v-text);
    white-space: nowrap;
}

.v-stats-label {
    font-size: .75rem;
    color: var(--v-text2);
    white-space: nowrap;
}

@media (max-width: 767.98px) {
    .v-stats-banner { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 479.98px) {
    .v-stats-banner { grid-template-columns: 1fr 1fr; }
    .v-stats-item   { padding: 12px 14px; gap: 10px; }
    .v-stats-icon   { width: 36px; height: 36px; font-size: .9rem; }
    .v-stats-value  { font-size: .9rem; }
}

/* =====================================================
   HOME PAGE — VIDEO CARDS & LAYOUT
   ===================================================== */

/* ── Section header ───────────────────────────────── */
.v-home-header {
    display: flex;
    align-items: center;
    gap: 12px;
}

.v-home-section-title {
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--v-text);
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0;
}

.v-home-title-bar {
    display: inline-block;
    width: 4px;
    height: 20px;
    background: var(--v-accent);
    border-radius: 2px;
    flex-shrink: 0;
}

/* ── Home video card ──────────────────────────────── */
.v-home-card {
    display: flex;
    flex-direction: column;
    background: var(--v-bg2);
    border: 1px solid var(--v-border);
    border-radius: var(--v-radius);
    overflow: hidden;
    color: var(--v-text);
    text-decoration: none;
    transition: border-color .2s, transform .2s;
    height: 100%;
}
.v-home-card:hover {
    border-color: var(--v-accent);
    transform: translateY(-2px);
    color: var(--v-text);
}

/* Thumbnail */
.v-home-thumb {
    position: relative;
    aspect-ratio: 9/14;
    background: var(--v-bg3);
    overflow: hidden;
    flex-shrink: 0;
}
.v-home-thumb-placeholder {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    color: var(--v-text3); font-size: 2rem;
}
.v-home-thumb img { width: 100%; height: 100%; object-fit: cover; }

/* Country badge bottom-left */
.v-home-country-badge {
    position: absolute; bottom: 34px; left: 8px;
    background: rgba(0,0,0,.55);
    color: #fff; font-size: .65rem; font-weight: 600;
    padding: 2px 7px; border-radius: 4px;
    display: flex; align-items: center; gap: 3px;
}

/* Info block */
.v-home-info {
    padding: 10px 10px 6px;
    flex: 1;
}

.v-home-title-text {
    font-size: .82rem;
    font-weight: 600;
    color: var(--v-text);
    line-height: 1.4;
    margin-bottom: 6px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.v-home-stats {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: .72rem;
    color: var(--v-text2);
    margin-bottom: 6px;
}
.v-home-stats i { font-size: .7rem; }

.v-home-author {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: .72rem;
    color: var(--v-text2);
}

/* Download button */
.v-home-dl {
    padding: 0 10px 10px;
}
.v-home-dl-btn {
    width: 100%;
    background: none;
    border: 1px solid var(--v-accent);
    border-radius: 7px;
    color: var(--v-accent);
    font-size: .78rem;
    font-weight: 700;
    font-family: inherit;
    padding: 7px 10px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    transition: background .15s, color .15s;
}
.v-home-dl-btn:hover {
    background: var(--v-accent);
    color: #fff;
}

/* ── Home keywords sidebar grid ───────────────────── */
.v-home-kw-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
    padding: 12px 14px;
}
.v-home-kw-chip {
    background: var(--v-bg3);
    border: 1px solid var(--v-border);
    border-radius: 6px;
    padding: 6px 8px;
    text-decoration: none;
    transition: border-color .15s, background .15s;
    display: flex;
    flex-direction: column;
    gap: 1px;
}
.v-home-kw-chip:hover {
    border-color: var(--v-accent);
    background: rgba(252,81,0,.06);
}
.v-home-kw-name {
    font-size: .75rem;
    font-weight: 600;
    color: var(--v-text2);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.v-home-kw-chip:hover .v-home-kw-name { color: var(--v-accent); }
.v-home-kw-count {
    font-size: .65rem;
    color: var(--v-text3);
}
