/*
Theme Name: VGTube
Theme URI: https://vgtube.local
Author: VGTube
Description: A dark video library WordPress theme with multi-platform support, custom categories, and dynamic options.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GPL-2.0-or-later
Text Domain: vgtube
*/

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0E0E10;--bg2:#18181B;--bg3:#1F1F23;--bg4:#26262C;--bg5:#2E2E36;
  --accent:#9147FF;--accent2:#772CE8;
  --red:#E63946;--green:#00F593;--gold:#F59E0B;
  --text:#EFEFF1;--muted:#ADADB8;--muted2:#6B7280;
  --border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.12);
  --hover:rgba(255,255,255,0.05);
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Exo 2',sans-serif;min-height:100vh;overflow-x:hidden}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--accent)}

/* TOPBAR */
.topbar{position:fixed;top:0;left:0;right:0;height:58px;background:rgba(24,24,27,.97);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 18px;z-index:1000;gap:12px}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;cursor:pointer;flex-shrink:0}
.logo-icon{width:36px;height:36px;background:var(--red);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:19px;font-weight:900;color:#fff;box-shadow:0 0 18px rgba(230,57,70,.4)}
.logo-text{font-size:21px;font-weight:900;letter-spacing:-.04em;color:var(--text)}
.logo-text span{color:var(--red)}
.search-wrap{flex:1;max-width:560px;display:flex}
.search-input{flex:1;background:var(--bg3);border:1px solid var(--border2);border-right:none;color:var(--text);padding:9px 15px;font-family:'Exo 2',sans-serif;font-size:14px;border-radius:6px 0 0 6px;outline:none;transition:border-color .2s}
.search-input:focus{border-color:var(--accent)}
.search-input::placeholder{color:var(--muted2)}
.search-btn{background:var(--bg4);border:1px solid var(--border2);color:var(--muted);padding:9px 13px;cursor:pointer;border-radius:0 6px 6px 0;transition:all .2s;font-size:15px}
.search-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.topbar-btns{display:flex;align-items:center;gap:7px;flex-shrink:0}
.tbtn{display:flex;align-items:center;gap:5px;padding:7px 13px;border-radius:6px;font-family:'Exo 2',sans-serif;font-size:12px;font-weight:700;cursor:pointer;border:none;transition:all .2s;white-space:nowrap}
.tbtn-ghost{background:var(--bg3);color:var(--muted);border:1px solid var(--border)}
.tbtn-ghost:hover{color:var(--text);border-color:var(--border2)}
.tbtn-purple{background:var(--accent);color:#fff}
.tbtn-purple:hover{background:var(--accent2);transform:translateY(-1px);box-shadow:0 4px 18px rgba(145,71,255,.4)}
.tbtn-red{background:var(--red);color:#fff}
.tbtn-red:hover{background:#c0323f;transform:translateY(-1px)}
.tbtn-green{background:var(--green);color:var(--bg);font-weight:800}
.tbtn-green:hover{opacity:.9;transform:translateY(-1px)}

/* LAYOUT */
.layout{display:flex;margin-top:58px;min-height:calc(100vh - 58px)}
.sidebar{width:226px;flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);padding:10px 0;position:sticky;top:58px;height:calc(100vh - 58px);overflow-y:auto}
.sb-sec{padding-bottom:10px;border-bottom:1px solid var(--border);margin-bottom:5px}
.sb-lbl{font-size:9.5px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--muted2);padding:7px 14px 4px}
.sb-item{display:flex;align-items:center;gap:9px;padding:6px 13px;cursor:pointer;border-left:3px solid transparent;font-size:12.5px;font-weight:500;color:var(--muted);transition:all .15s}
.sb-item:hover{background:var(--hover);color:var(--text)}
.sb-item.active{background:rgba(145,71,255,.1);border-left-color:var(--accent);color:var(--accent)}
.sb-icon{font-size:15px;width:17px;text-align:center;flex-shrink:0}
.sb-cnt{margin-left:auto;font-size:9.5px;background:var(--bg4);color:var(--muted2);padding:1px 5px;border-radius:8px;font-family:'JetBrains Mono',monospace}
.sb-del{margin-left:auto;opacity:0;font-size:10px;color:var(--red);cursor:pointer;padding:1px 5px;border-radius:3px;transition:all .15s}
.sb-item:hover .sb-del{opacity:1}
.sb-del:hover{background:rgba(230,57,70,.15)}
.main{flex:1;padding:18px 22px;overflow:hidden;min-width:0}

/* CATEGORY TABS */
.cat-tabs{display:flex;gap:6px;margin-bottom:18px;overflow-x:auto;padding-bottom:3px}
.cat-tabs::-webkit-scrollbar{height:0}
.ctab{padding:5px 13px;border-radius:16px;font-size:11.5px;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .2s;background:var(--bg3);border:1px solid var(--border);color:var(--muted);font-family:'Exo 2',sans-serif;display:flex;align-items:center;gap:4px}
.ctab:hover{color:var(--text);border-color:var(--border2)}
.ctab.active{background:var(--accent);border-color:var(--accent);color:#fff}
.ctab .tdel{font-size:9px;opacity:.5;margin-left:2px;display:none}
.ctab:hover .tdel{display:inline}
.ctab .tdel:hover{opacity:1}

/* PLAYER */
.playsec{margin-bottom:26px}
.npl{font-size:9.5px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;display:flex;align-items:center;gap:7px}
.npl::before{content:'';width:12px;height:2px;background:var(--accent)}
.pwrap{display:grid;grid-template-columns:1fr 310px;gap:16px;align-items:start}
.pframe{width:100%;aspect-ratio:16/9;background:#000;border-radius:10px;overflow:hidden;position:relative}
.pframe iframe,.pframe video{width:100%;height:100%;border:none}
.pph{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:var(--bg3);cursor:pointer}
.ppbtn{width:72px;height:72px;background:rgba(255,255,255,.08);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;border:2px solid rgba(255,255,255,.15);transition:all .3s}
.ppbtn:hover{background:var(--red);border-color:var(--red);transform:scale(1.08);box-shadow:0 0 28px rgba(230,57,70,.5)}
.pmeta{margin-top:11px}
.pm-t{font-size:16px;font-weight:700;line-height:1.3;margin-bottom:6px}
.pm-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:9px}
.pm-ch{font-size:12.5px;font-weight:600;color:var(--accent)}
.pm-st{font-size:11.5px;color:var(--muted);display:flex;gap:8px}
.pm-plat{font-size:9px;font-weight:800;padding:2px 7px;border-radius:3px;letter-spacing:.08em;text-transform:uppercase}
.pm-acts{display:flex;gap:6px;flex-wrap:wrap}
.abtn{display:flex;align-items:center;gap:4px;padding:5px 11px;background:var(--bg3);border:1px solid var(--border);border-radius:5px;color:var(--muted);font-size:11px;font-family:'Exo 2',sans-serif;font-weight:700;cursor:pointer;transition:all .2s;white-space:nowrap}
.abtn:hover{background:var(--bg4);color:var(--text)}
.abtn.liked{color:var(--red);border-color:var(--red);background:rgba(230,57,70,.08)}
.abtn.dl{color:var(--green);border-color:var(--green)}
.abtn.won{color:var(--gold);border-color:var(--gold)}

/* QUEUE */
.queue{background:var(--bg2);border:1px solid var(--border);border-radius:10px;overflow:hidden;max-height:470px;display:flex;flex-direction:column}
.qh{padding:9px 13px;background:var(--bg3);border-bottom:1px solid var(--border);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:space-between}
.qh span{color:var(--muted2);font-size:10.5px;font-weight:400}
.qlist{overflow-y:auto;flex:1}
.qi{display:flex;gap:8px;padding:8px 10px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border);align-items:flex-start}
.qi:hover{background:var(--hover)}
.qi.playing{background:rgba(145,71,255,.1);border-left:2px solid var(--accent)}
.qth{width:80px;height:46px;border-radius:4px;overflow:hidden;flex-shrink:0;background:var(--bg4);position:relative}
.qth img{width:100%;height:100%;object-fit:cover}
.qth-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:17px}
.qd{position:absolute;bottom:2px;right:2px;background:rgba(0,0,0,.87);font-size:8.5px;font-family:'JetBrains Mono',monospace;padding:1px 3px;border-radius:2px;color:#fff}
.qi-inf{flex:1;min-width:0}
.qi-t{font-size:11px;font-weight:600;line-height:1.35;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:2px}
.qi-ch{font-size:10px;color:var(--muted)}
.sbdg{font-size:8.5px;font-weight:800;padding:1px 5px;border-radius:2px;letter-spacing:.05em;display:inline-block;margin-top:2px}
.s-yt{background:rgba(255,0,0,.14);color:#FF4444}
.s-vm{background:rgba(26,183,234,.14);color:#1AB7EA}
.s-dm{background:rgba(0,133,255,.14);color:#0085FF}
.s-tw{background:rgba(145,71,255,.14);color:var(--accent)}
.s-fb{background:rgba(24,119,242,.14);color:#1877F2}
.s-ig{background:rgba(225,48,108,.14);color:#E1306C}
.s-tk{background:rgba(105,201,208,.14);color:#69C9D0}
.s-gd{background:rgba(52,168,83,.14);color:#34A853}
.s-lc{background:rgba(0,245,147,.14);color:var(--green)}
.s-xx{background:rgba(100,100,100,.14);color:#888}

/* VIDEO GRID */
.sec{margin-bottom:26px}
.sec-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px}
.sec-title{font-size:16px;font-weight:800;display:flex;align-items:center;gap:8px}
.sec-acts{display:flex;gap:7px}
.sbtn{font-size:11px;color:var(--muted);cursor:pointer;font-weight:700;background:none;border:none;font-family:'Exo 2',sans-serif;padding:4px 9px;border-radius:4px;transition:all .2s}
.sbtn:hover{color:var(--accent);background:rgba(145,71,255,.08)}
.vgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px}
.vcard{cursor:pointer;border-radius:9px;overflow:hidden;transition:transform .2s}
.vcard:hover{transform:translateY(-4px)}
.vcard:hover .vov{opacity:1}
.vcard:hover .vth-img{transform:scale(1.04)}
.vth{position:relative;width:100%;aspect-ratio:16/9;background:var(--bg3);border-radius:9px;overflow:hidden;margin-bottom:8px}
.vth-img{width:100%;height:100%;object-fit:cover;transition:transform .3s;display:block}
.vth-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:30px}
.vov{position:absolute;inset:0;background:rgba(0,0,0,.52);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}
.vov-p{width:44px;height:44px;background:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 0 22px rgba(230,57,70,.6)}
.vdur{position:absolute;bottom:5px;right:5px;background:rgba(0,0,0,.88);color:#fff;font-size:9.5px;font-family:'JetBrains Mono',monospace;padding:2px 5px;border-radius:3px}
.vq-btn{position:absolute;top:5px;right:5px;width:22px;height:22px;background:rgba(0,0,0,.7);border:none;border-radius:4px;color:#fff;font-size:15px;line-height:1;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:2}
.vcard:hover .vq-btn{display:flex}
.vsrc{position:absolute;top:5px;left:5px}
.vnow{position:absolute;top:5px;right:5px;background:var(--red);color:#fff;font-size:7.5px;font-weight:900;padding:2px 5px;border-radius:2px;letter-spacing:.08em}
.vlive{background:var(--red);color:#fff;font-size:7.5px;font-weight:900;padding:2px 5px;border-radius:2px;display:inline-flex;align-items:center;gap:3px}
.ldot{width:5px;height:5px;background:#fff;border-radius:50%;animation:lp 1s ease-in-out infinite}
@keyframes lp{0%,100%{opacity:1}50%{opacity:.3}}
.nonembed{position:absolute;inset:0;background:rgba(0,0,0,.65);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:8px}
.ne-lbl{font-size:9px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:2px 8px;border-radius:3px;border:1px solid currentColor}
.vcinfo{padding:0 2px}
.vct{font-size:12px;font-weight:700;line-height:1.4;color:var(--text);margin-bottom:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.vcc{font-size:11px;color:var(--muted);margin-bottom:2px}
.vcm{font-size:10px;color:var(--muted);opacity:.7;display:flex;gap:4px;flex-wrap:wrap}

/* MODALS */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.84);z-index:2000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s;backdrop-filter:blur(6px)}
.overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:14px;padding:28px 26px;width:100%;max-width:560px;max-height:88vh;overflow-y:auto;transform:translateY(14px);transition:transform .25s}
.overlay.open .modal{transform:translateY(0)}
.mt{font-size:18px;font-weight:800;margin-bottom:4px}
.ms{font-size:12.5px;color:var(--muted);margin-bottom:20px;line-height:1.6}
.fg{margin-bottom:13px}
.fl{font-size:9.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted2);display:block;margin-bottom:4px}
.fi,.fsel,.fta{width:100%;background:var(--bg);border:1px solid var(--border2);color:var(--text);padding:8px 12px;font-family:'Exo 2',sans-serif;font-size:13px;border-radius:7px;outline:none;transition:border-color .2s}
.fi:focus,.fsel:focus,.fta:focus{border-color:var(--accent)}
.fi::placeholder{color:var(--muted2)}
.fsel option{background:var(--bg2)}
.fta{resize:vertical;min-height:56px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.mfoot{display:flex;gap:9px;justify-content:flex-end;margin-top:20px}
.mbtn{padding:8px 18px;border-radius:7px;font-family:'Exo 2',sans-serif;font-size:12.5px;font-weight:700;cursor:pointer;border:none;transition:all .2s}
.mb-ghost{background:var(--bg3);color:var(--muted);border:1px solid var(--border)}
.mb-ghost:hover{color:var(--text)}
.mb-acc{background:var(--accent);color:#fff}
.mb-acc:hover{background:var(--accent2)}
.mb-grn{background:var(--green);color:var(--bg);font-weight:800}
.mb-grn:hover{opacity:.9}
.uchip{display:none;align-items:center;gap:9px;background:var(--bg3);border:1px solid var(--border2);border-radius:7px;padding:9px 11px;margin-top:7px}
.uchip.show{display:flex}
.uchip-th{width:68px;height:38px;border-radius:4px;overflow:hidden;background:var(--bg4);flex-shrink:0}
.uchip-th img{width:100%;height:100%;object-fit:cover}
.uchip-i{flex:1;min-width:0}
.uchip-t{font-size:11px;font-weight:700;margin-bottom:1px}
.uchip-d{font-size:10px;color:var(--muted)}
.pwarn{background:rgba(245,158,11,.07);border:1px solid rgba(245,158,11,.2);border-radius:7px;padding:9px 12px;margin-top:7px;font-size:11.5px;color:var(--gold);line-height:1.6;display:none}
.pwarn.show{display:block}
.dropz{border:2px dashed var(--border2);border-radius:9px;padding:24px;text-align:center;cursor:pointer;transition:all .2s;margin-bottom:13px;background:var(--bg3)}
.dropz:hover,.dropz.drag{border-color:var(--accent);background:rgba(145,71,255,.06)}
.dropz-ico{font-size:34px;margin-bottom:8px;display:block}
.dropz-t{font-size:13px;font-weight:700;margin-bottom:3px}
.dropz-s{font-size:11.5px;color:var(--muted)}
.fhinput{display:none}
.or-div{text-align:center;font-size:11px;color:var(--muted2);margin:4px 0 10px}
.emjgrid{display:grid;grid-template-columns:repeat(8,1fr);gap:5px;max-height:170px;overflow-y:auto}
.emj{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:20px;border-radius:6px;cursor:pointer;transition:all .15s;background:var(--bg3);border:2px solid transparent}
.emj:hover{background:var(--bg4);transform:scale(1.1)}
.emj.sel{border-color:var(--accent);background:rgba(145,71,255,.12)}
.swatches{display:flex;gap:7px;flex-wrap:wrap;margin-top:5px}
.sw{width:26px;height:26px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:all .15s}
.sw:hover{transform:scale(1.15)}
.sw.sel{border-color:#fff;box-shadow:0 0 0 2px currentColor}

/* TOAST */
.toast{position:fixed;bottom:20px;right:20px;background:var(--bg2);border:1px solid var(--green);color:var(--text);padding:10px 16px;border-radius:8px;font-size:12.5px;font-weight:600;z-index:3000;transform:translateY(65px);opacity:0;transition:all .3s;display:flex;align-items:center;gap:7px}
.toast.show{transform:translateY(0);opacity:1}
.ti{color:var(--green);font-size:14px}

/* EMPTY */
.empty{text-align:center;padding:44px 18px;color:var(--muted)}
.ei{font-size:40px;margin-bottom:11px;display:block}
.et{font-size:16px;font-weight:700;color:var(--text);margin-bottom:5px}
.es{font-size:12.5px;line-height:1.6}

/* WP ADMIN BAR OFFSET */
.admin-bar .topbar{top:32px}
@media(max-width:782px){.admin-bar .topbar{top:46px}}

@media(max-width:900px){.sidebar{display:none}.pwrap{grid-template-columns:1fr}.queue{max-height:260px}}
@media(max-width:560px){.topbar{padding:0 9px}.logo-text{display:none}.search-wrap{display:none}.main{padding:12px}.vgrid{grid-template-columns:repeat(2,1fr);gap:9px}}

/* AUTH PAGE */
.auth-wrap{min-height:calc(100vh - 58px);display:flex;align-items:center;justify-content:center;padding:24px 16px;background:var(--bg)}
.auth-box{width:100%;max-width:420px;background:var(--bg2);border:1px solid var(--border2);border-radius:16px;padding:36px 32px}
.auth-logo{text-align:center;margin-bottom:24px}
.auth-site-name{font-size:22px;font-weight:900;letter-spacing:-.03em;margin-top:6px}
.auth-tabs{display:flex;background:var(--bg3);border-radius:8px;padding:3px;margin-bottom:24px;gap:3px}
.auth-tab{flex:1;padding:7px;border:none;background:none;color:var(--muted);font-family:'Exo 2',sans-serif;font-size:13px;font-weight:700;border-radius:6px;cursor:pointer;transition:all .2s}
.auth-tab.active{background:var(--bg4);color:var(--text)}
.auth-form{display:none}
.auth-form.active{display:block}
.auth-fg{margin-bottom:14px}
.auth-fl{font-size:9.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted2);display:block;margin-bottom:4px}
.auth-fi{width:100%;background:var(--bg);border:1px solid var(--border2);color:var(--text);padding:9px 12px;font-family:'Exo 2',sans-serif;font-size:13px;border-radius:7px;outline:none;transition:border-color .2s}
.auth-fi:focus{border-color:var(--accent)}
.auth-fi::placeholder{color:var(--muted2)}
.auth-pw-wrap{position:relative}
.auth-pw-wrap .auth-fi{padding-right:38px}
.auth-eye{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--muted);cursor:pointer;font-size:15px;padding:2px;line-height:1}
.auth-eye:hover{color:var(--text)}
.auth-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;font-size:12px}
.auth-check{display:flex;align-items:center;gap:6px;color:var(--muted);cursor:pointer}
.auth-check input{accent-color:var(--accent)}
.auth-link{color:var(--accent);text-decoration:none;font-size:12px}
.auth-link:hover{text-decoration:underline}
.auth-btn{width:100%;padding:10px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-family:'Exo 2',sans-serif;font-size:14px;font-weight:800;cursor:pointer;transition:all .2s;margin-top:4px}
.auth-btn:hover{background:var(--accent2);transform:translateY(-1px);box-shadow:0 4px 18px rgba(145,71,255,.4)}
.auth-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}
.auth-msg{font-size:12px;border-radius:7px;padding:9px 12px;margin-bottom:12px;display:none;line-height:1.5}
.auth-msg.show{display:block}
.auth-msg.error{background:rgba(230,57,70,.08);border:1px solid rgba(230,57,70,.25);color:var(--red)}
.auth-msg.success{background:rgba(0,245,147,.08);border:1px solid rgba(0,245,147,.25);color:var(--green)}
.auth-strength{font-size:10.5px;font-weight:700;margin-top:5px;letter-spacing:.04em}
.auth-strength.weak{color:var(--red)}
.auth-strength.fair{color:var(--gold)}
.auth-strength.good{color:#00B0FF}
.auth-strength.strong{color:var(--green)}
