/* ═══ TOKENS ═══ */
:root{
  --bg:#0a0803;--bg2:#0d0b06;--card:#14110a;--border:#2a2318;
  --border-warm:#3d3220;
  --gold:#d4a52e;--gold2:#a88420;--gold-bright:#e8b83a;--gold-glow:rgba(212,165,46,0.12);
  --green:#3ecf8e;--red:#e85d5d;
  --hi:#f0ebe0;--mid:#c4bba8;--lo:#7a7263;--faint:#4a4538;
  --r:10px;--r2:16px;--ease:cubic-bezier(.4,0,.2,1);--ease-bounce:cubic-bezier(.34,1.56,.64,1);
  --nav:52px;--bot:60px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);color:var(--mid);
  font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;line-height:1.6;
  overflow-x:hidden;padding-top:var(--nav);padding-bottom:var(--bot);
}
button{cursor:pointer;font-family:inherit;border:none;background:none}
a{text-decoration:none;color:inherit}
input,textarea,select{font-family:inherit}
::-webkit-scrollbar{width:3px;height:3px}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:2px}

/* ═══ NAV ═══ */
.topnav{
  position:fixed;top:0;left:0;right:0;z-index:900;height:var(--nav);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 14px;background:rgba(17,16,8,.95);
  backdrop-filter:blur(20px);border-bottom:1px solid var(--border);
}
.logo{font-family:'Syne',sans-serif;font-weight:800;font-size:20px;color:var(--hi);display:flex;align-items:center;gap:7px}
.logo-dot{width:7px;height:7px;background:var(--green);border-radius:50%;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.logo em{color:var(--gold);font-style:normal}
.nav-right{display:flex;align-items:center;gap:8px}
.btn-sm{padding:6px 14px;border-radius:6px;font-size:12px;font-weight:600;transition:all .2s}
.btn-ol{border:1px solid var(--border);color:var(--mid)}
.btn-ol:hover{border-color:var(--gold);color:var(--gold)}
.btn-gd{background:var(--gold);color:#000}
.btn-gd:hover{background:#f7b540}
.nav-avi{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  color:#000;font-size:13px;font-weight:800;
  display:none;align-items:center;justify-content:center;
  border:2px solid var(--border);cursor:pointer;position:relative;
}
.nav-avi.show{display:flex}
.nav-avi-menu{
  position:absolute;top:40px;right:0;
  background:var(--card);border:1px solid var(--border);border-radius:var(--r);
  min-width:180px;overflow:hidden;display:none;z-index:1000;
}
.nav-avi-menu.open{display:block}
.nav-avi-menu a{
  display:block;padding:12px 16px;font-size:13px;color:var(--mid);
  transition:background .2s;cursor:pointer;
}
.nav-avi-menu a:hover{background:var(--bg);color:var(--hi)}
.nav-avi-menu a.danger{color:var(--red)}
/* Notification bell */
.nav-bell{
  width:32px;height:32px;border-radius:50%;
  background:var(--card);border:1px solid var(--border);
  color:var(--mid);font-size:16px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;position:relative;transition:all .2s;
}
.nav-bell:hover{border-color:var(--gold);color:var(--gold)}
.notif-badge{
  position:absolute;top:-3px;right:-3px;
  background:var(--red);color:#fff;font-size:9px;font-weight:800;
  min-width:16px;height:16px;border-radius:8px;
  display:none;align-items:center;justify-content:center;padding:0 4px;
}
.notif-badge.show{display:flex}
/* Notification dropdown */
.notif-dropdown{
  position:absolute;top:44px;right:-8px;
  background:var(--card);border:1px solid var(--border);border-radius:var(--r);
  width:320px;max-width:calc(100vw - 20px);
  max-height:400px;display:none;flex-direction:column;
  box-shadow:0 12px 40px rgba(0,0,0,.6);z-index:1001;overflow:hidden;
}
.notif-dropdown.open{display:flex}
.notif-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 14px;border-bottom:1px solid var(--border);flex-shrink:0;
}
.notif-head-title{font-family:'Syne',sans-serif;font-size:14px;font-weight:800;color:var(--hi)}
.notif-mark-read{font-size:11px;color:var(--gold);cursor:pointer;font-weight:600}
.notif-list{overflow-y:auto;flex:1}
.notif-item{
  display:flex;gap:10px;padding:11px 14px;
  border-bottom:1px solid rgba(42,39,32,.4);cursor:pointer;transition:background .2s;
}
.notif-item:hover{background:var(--bg)}
.notif-item.unread{border-left:3px solid var(--gold)}
.notif-avi{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;font-size:14px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.notif-body{flex:1}
.notif-text{font-size:12px;color:var(--mid);line-height:1.5}
.notif-text strong{color:var(--hi)}
.notif-time{font-size:10px;color:var(--lo);margin-top:2px}
.notif-empty{padding:30px;text-align:center;font-size:13px;color:var(--lo)}
/* Settings modal */
.settings-overlay{
  position:fixed;inset:0;z-index:1900;
  background:rgba(0,0,0,.85);backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;padding:20px;
}
.settings-overlay.open{display:flex}
.settings-modal{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r2);
  width:100%;max-width:400px;overflow:hidden;
}
.settings-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border)}
.settings-title{font-family:'Syne',sans-serif;font-size:17px;font-weight:800;color:var(--hi)}
.settings-body{padding:8px 0}
.setting-row{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid rgba(42,39,32,.4)}
.setting-info .s-label{font-size:14px;font-weight:600;color:var(--hi)}
.setting-info .s-desc{font-size:11px;color:var(--lo);margin-top:2px}
.toggle-pill{width:42px;height:24px;border-radius:12px;background:var(--border);position:relative;cursor:pointer;transition:background .3s;flex-shrink:0}
.toggle-pill.on{background:var(--gold)}
.toggle-pill::after{content:'';position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .3s}
.toggle-pill.on::after{transform:translateX(18px)}
/* Unmute overlay */
.unmute-overlay{
  position:absolute;inset:0;z-index:6;
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;opacity:0;transition:opacity .4s;
}
.unmute-overlay.show{opacity:1}
.unmute-pill{
  background:rgba(0,0,0,.75);color:#fff;
  padding:10px 22px;border-radius:30px;font-size:14px;font-weight:700;
  display:flex;align-items:center;gap:8px;
  animation:unmutePulse 2s ease infinite;
}
@keyframes unmutePulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
/* 3-dot menu in TikFeed */
.tik-options-btn{
  position:absolute;top:16px;right:62px;z-index:20;
  background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.15);
  color:#fff;width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;
}
.tik-options-menu{
  position:absolute;top:62px;right:16px;z-index:25;
  background:var(--card);border:1px solid var(--border);border-radius:var(--r);
  min-width:180px;overflow:hidden;display:none;
  box-shadow:0 8px 30px rgba(0,0,0,.7);
}
.tik-options-menu.open{display:block}
.tik-options-menu button{
  width:100%;padding:13px 16px;background:none;border:none;
  color:var(--mid);font-size:13px;text-align:left;cursor:pointer;
  display:flex;align-items:center;gap:10px;transition:background .2s;font-family:inherit;
}
.tik-options-menu button:hover{background:var(--bg);color:var(--hi)}
.tik-options-menu button.danger{color:var(--red)}

/* ═══ BOTTOM NAV ═══ */
.botnav{
  position:fixed;bottom:0;left:0;right:0;z-index:900;height:var(--bot);
  display:flex;align-items:center;justify-content:space-around;
  background:rgba(13,12,7,.97);border-top:1px solid var(--border);
}
.bn-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 0;cursor:pointer;color:var(--lo);transition:color .2s}
.bn-item.active{color:var(--gold)}
.bn-ico{font-size:20px;line-height:1}
.bn-lbl{font-size:10px;font-weight:600}
.bn-badge{position:absolute;top:2px;right:50%;transform:translateX(50%);margin-right:-14px;background:var(--red);color:#fff;font-size:9px;font-weight:800;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.bn-item{position:relative}
.upload-pill{
  width:44px;height:30px;border-radius:8px;background:var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;color:#000;font-weight:800;
  box-shadow:0 0 16px rgba(240,165,0,.35);
}

/* ═══ SCREENS ═══ */
.screen{display:none}
.screen.active{display:block}

/* ═══ HERO ═══ */
.hero{
  position:relative;overflow:hidden;
  background:linear-gradient(160deg,#1a1508,#0d0c07,#0a100d);
  padding:18px 16px 16px;border-bottom:1px solid var(--border);
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 20% 30%,rgba(240,165,0,.1),transparent 55%),
             radial-gradient(circle at 80% 70%,rgba(62,207,142,.06),transparent 45%);
}
.hero-inner{position:relative;z-index:1}
.hero-badge{
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(240,165,0,.1);border:1px solid rgba(240,165,0,.25);
  color:var(--gold);padding:4px 12px;border-radius:20px;
  font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;margin-bottom:16px;
}
.hero-badge::before{content:'';width:5px;height:5px;background:var(--gold);border-radius:50%;animation:blink 1.5s infinite}
.hero-h1{font-family:'Syne',sans-serif;font-weight:800;font-size:clamp(28px,8vw,48px);line-height:1.05;letter-spacing:-1.5px;color:var(--hi);margin-bottom:12px}
.hero-h1 em{font-style:normal;color:var(--gold)}
.hero-sub{font-size:13px;color:var(--lo);margin-bottom:20px;line-height:1.65}
.hero-ctas{display:flex;gap:10px;flex-wrap:wrap}
.btn-hero{
  padding:12px 22px;background:var(--gold);color:#000;
  border-radius:var(--r);font-size:14px;font-weight:700;
  display:flex;align-items:center;gap:6px;transition:all .2s;
  box-shadow:0 6px 20px rgba(240,165,0,.28);
}
.btn-hero:active{background:#f7b540}
.btn-hero-ghost{padding:12px 22px;border:1px solid var(--border);border-radius:var(--r);color:var(--mid);font-size:14px;font-weight:500}
.hero-stats{display:flex;gap:0;margin-top:22px;padding-top:18px;border-top:1px solid var(--border)}
.stat{flex:1;text-align:center}
.stat:not(:last-child){border-right:1px solid var(--border)}
.stat-n{font-family:'Syne',sans-serif;font-size:20px;font-weight:800;color:var(--hi)}
.stat-n span{color:var(--gold)}
.stat-l{font-size:10px;color:var(--lo);text-transform:uppercase;letter-spacing:.8px}

/* ═══ CATEGORIES ═══ */
.cat-bar{display:flex;gap:8px;padding:12px 16px;overflow-x:auto;border-bottom:1px solid var(--border);background:var(--bg2);scrollbar-width:none}
.cat-bar::-webkit-scrollbar{display:none}
.cat-pill{
  padding:7px 16px;border-radius:20px;border:1px solid var(--border);background:transparent;
  color:var(--lo);font-size:12px;font-weight:600;white-space:nowrap;
  display:flex;align-items:center;gap:5px;transition:all .2s;flex-shrink:0;
}
.cat-pill.active{background:var(--gold);color:#000;border-color:var(--gold)}

/* ═══ SECTION ═══ */
.sec{padding:18px 16px}
.s-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.s-title{font-family:'Syne',sans-serif;font-size:17px;font-weight:800;color:var(--hi);display:flex;align-items:center;gap:8px}
.s-title::before{content:'';width:3px;height:18px;background:var(--gold);border-radius:2px;flex-shrink:0}
.see-all{font-size:12px;color:var(--gold);font-weight:600}

/* ═══ VIDEO GRID ═══ */
.vid-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}
.vid-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;cursor:pointer;transition:transform .2s;position:relative}
.vid-card:active{transform:scale(.97)}
.vid-card.premium .vid-thumb-bg{filter:blur(5px);transform:scale(1.08)}
.premium-gate{
  position:absolute;inset:0;z-index:5;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:6px;background:rgba(13,12,7,.82);backdrop-filter:blur(4px);
}
.gate-icon{font-size:22px}
.gate-txt{font-size:11px;color:var(--mid);text-align:center;line-height:1.4;padding:0 8px}
.btn-gate{padding:6px 16px;background:var(--gold);color:#000;border-radius:6px;font-size:11px;font-weight:700;margin-top:2px}
.vid-thumb{aspect-ratio:16/9;position:relative;overflow:hidden}
.vid-thumb-bg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:28px;transition:transform .3s}
.vid-card:active .vid-thumb-bg{transform:scale(1.04)}
.vid-dur{position:absolute;bottom:5px;right:5px;background:rgba(13,12,7,.85);color:var(--hi);font-size:10px;padding:1px 5px;border-radius:3px;z-index:2}
.vid-live-tag{position:absolute;top:5px;left:5px;background:var(--red);color:#fff;font-size:9px;font-weight:700;letter-spacing:.6px;padding:2px 6px;border-radius:3px;z-index:2;display:flex;align-items:center;gap:4px}
.vid-live-tag::before{content:'';width:4px;height:4px;background:#fff;border-radius:50%;animation:blink 1s infinite}
.vid-prem-tag{position:absolute;top:5px;right:5px;background:var(--gold);color:#000;font-size:9px;font-weight:800;padding:2px 6px;border-radius:3px;z-index:2}
.vid-body{padding:10px}
.vid-row{display:flex;align-items:center;gap:7px;margin-bottom:6px}
.avi{width:26px;height:26px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;border:2px solid var(--border)}
.cname{font-size:11px;font-weight:600;color:var(--mid)}
.cchk{color:var(--gold);font-size:9px;margin-left:2px}
.vid-title{font-size:12px;font-weight:600;color:var(--hi);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:5px}
.vid-meta{display:flex;gap:7px;font-size:10px;color:var(--lo)}

/* ═══ HOME FEED GRID — 2-col mobile, bigger cards ═══ */
.home-feed-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:8px;
  padding:10px 12px;
}
@media(min-width:600px){
  .home-feed-grid{grid-template-columns:repeat(3,1fr);gap:10px;padding:12px 16px}
}
@media(min-width:960px){
  .home-feed-grid{grid-template-columns:repeat(3,1fr);gap:12px}
}

/* Real video cards from DB */
.real-vid-card{border-radius:var(--r);overflow:hidden;cursor:pointer;transition:transform .2s;position:relative;aspect-ratio:3/4;background:var(--bg2)}
.real-vid-card:active{transform:scale(.97)}
.real-vid-card video,.real-vid-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.real-vid-overlay{position:absolute;inset:0;background:linear-gradient(transparent 35%,rgba(0,0,0,.85) 100%);z-index:2}
.real-vid-info{position:absolute;bottom:0;left:0;right:0;padding:10px 8px;z-index:3}
.real-vid-creator{font-size:12px;font-weight:700;color:#fff;display:flex;align-items:center;gap:5px;margin-bottom:3px}
.real-vid-creator-dot{width:6px;height:6px;background:var(--green);border-radius:50%;flex-shrink:0}
.real-vid-title{font-size:12px;color:rgba(255,255,255,.85);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:4px}
.real-vid-stats{display:flex;gap:8px;font-size:11px;color:rgba(255,255,255,.6)}
.real-vid-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:36px;height:36px;border-radius:50%;background:rgba(240,165,0,.85);display:flex;align-items:center;justify-content:center;z-index:3;opacity:0;transition:opacity .2s}
.real-vid-card:hover .real-vid-play{opacity:1}

/* ═══ EMPTY STATE ═══ */
.empty-state{
  text-align:center;padding:40px 20px;
  display:flex;flex-direction:column;align-items:center;gap:12px;
}
.empty-ico{font-size:48px}
.empty-title{font-family:'Syne',sans-serif;font-size:18px;font-weight:800;color:var(--hi)}
.empty-sub{font-size:13px;color:var(--lo);line-height:1.6;max-width:280px}
.btn-empty{padding:12px 24px;background:var(--gold);color:#000;border-radius:var(--r);font-size:14px;font-weight:700;margin-top:4px}

/* ═══ THUMB COLORS ═══ */
.t1{background:linear-gradient(135deg,#1d1206,#2e1a00)}
.t2{background:linear-gradient(135deg,#07180d,#0c2215)}
.t3{background:linear-gradient(135deg,#1d1000,#2a1600)}
.t4{background:linear-gradient(135deg,#0c0819,#160a28)}
.t5{background:linear-gradient(135deg,#0a1a1a,#0e2828)}
.t6{background:linear-gradient(135deg,#1a1800,#262300)}
.t7{background:linear-gradient(135deg,#1c000e,#2a0018)}
.t8{background:linear-gradient(135deg,#081620,#0c1e2c)}
.a1{background:linear-gradient(135deg,#f0a500,#c47d0e);color:#000}
.a2{background:linear-gradient(135deg,#3ecf8e,#0ea572);color:#000}
.a3{background:linear-gradient(135deg,#ff6b35,#cc4400);color:#fff}
.a4{background:linear-gradient(135deg,#7c4dff,#4527a0);color:#fff}
.a5{background:linear-gradient(135deg,#29b6f6,#0277bd);color:#fff}
.a6{background:linear-gradient(135deg,#ef5350,#b71c1c);color:#fff}

/* ═══ LIVE ═══ */
.live-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
.live-scroll::-webkit-scrollbar{display:none}
.live-card{flex-shrink:0;width:240px;border-radius:var(--r);overflow:hidden;cursor:pointer;position:relative;aspect-ratio:16/9;transition:transform .2s}
.live-card:active{transform:scale(.97)}
.live-thumb{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:40px}
.live-info{position:absolute;inset:0;background:linear-gradient(transparent 30%,rgba(13,12,7,.95));display:flex;flex-direction:column;justify-content:flex-end;padding:14px}
.live-badge{position:absolute;top:8px;left:8px;background:var(--red);color:#fff;font-size:9px;font-weight:700;letter-spacing:.8px;padding:3px 8px;border-radius:4px;display:flex;align-items:center;gap:4px}
.live-badge::before{content:'';width:4px;height:4px;background:#fff;border-radius:50%;animation:blink 1s infinite}
.viewers{position:absolute;top:8px;right:8px;background:rgba(13,12,7,.75);color:var(--mid);font-size:10px;padding:3px 8px;border-radius:4px}
.live-title{font-family:'Syne',sans-serif;font-size:13px;font-weight:700;color:var(--hi);margin-bottom:2px}
.live-sub{font-size:11px;color:var(--lo)}

/* ═══ CREATORS ═══ */
.creators-scroll{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
.creators-scroll::-webkit-scrollbar{display:none}
.creator-card{flex-shrink:0;width:130px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:16px 12px;text-align:center;cursor:pointer}
.cc-avi{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;margin:0 auto 10px;border:2px solid var(--border);position:relative}
.online-dot{position:absolute;bottom:1px;right:1px;width:10px;height:10px;background:var(--green);border-radius:50%;border:2px solid var(--card)}
.cc-name{font-size:12px;font-weight:700;color:var(--hi);margin-bottom:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cc-handle{font-size:10px;color:var(--lo);margin-bottom:7px}
.cc-subs{font-size:10px;color:var(--gold);font-weight:700}
.follow-btn{margin-top:8px;width:100%;padding:6px;border:1px solid var(--border);border-radius:6px;color:var(--mid);font-size:11px;font-weight:600;transition:all .2s}
.follow-btn.following{background:rgba(62,207,142,.1);color:var(--green);border-color:rgba(62,207,142,.3)}

/* ═══ TAGS ═══ */
.tags-sec{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:18px 16px}
.tag-wrap{display:flex;flex-wrap:wrap;gap:8px}
.tag{padding:7px 14px;background:var(--card);border:1px solid var(--border);border-radius:20px;font-size:12px;color:var(--mid);cursor:pointer;display:flex;align-items:center;gap:7px;transition:all .2s}
.tag:active{border-color:var(--gold);color:var(--gold)}
.tag-ct{font-size:10px;color:var(--lo)}

/* ═══ PROMO ═══ */
.promo{margin:16px;border-radius:var(--r2);padding:28px 20px;background:linear-gradient(135deg,#1a1200,#0e0e0e,#001a0a);border:1px solid rgba(240,165,0,.18);position:relative;overflow:hidden}
.promo::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(240,165,0,.1),transparent 55%);pointer-events:none}
.promo-tag{display:inline-flex;align-items:center;gap:6px;background:rgba(62,207,142,.1);border:1px solid rgba(62,207,142,.25);color:var(--green);padding:3px 12px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;margin-bottom:12px;position:relative;z-index:1}
.promo-title{font-family:'Syne',sans-serif;font-size:22px;font-weight:800;color:var(--hi);letter-spacing:-1px;margin-bottom:8px;position:relative;z-index:1}
.promo-desc{font-size:13px;color:var(--lo);margin-bottom:18px;position:relative;z-index:1}
.btn-promo{display:inline-flex;align-items:center;gap:6px;padding:12px 22px;background:var(--gold);color:#000;border-radius:var(--r);font-size:14px;font-weight:700;position:relative;z-index:1}

/* ═══ UPLOAD SCREEN ═══ */
.upload-screen{padding:20px 16px}
.upload-area{
  border:2px dashed var(--border);border-radius:var(--r2);padding:32px 20px;
  text-align:center;cursor:pointer;transition:border-color .2s;margin-bottom:16px;
  display:flex;flex-direction:column;align-items:center;gap:10px;
}
.upload-area:hover,.upload-area.dragover{border-color:var(--gold)}
.upload-area input[type=file]{display:none}
.upload-ico{font-size:40px}
.upload-title{font-family:'Syne',sans-serif;font-size:14px;font-weight:800;color:var(--hi);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 10px}
.upload-sub{font-size:12px;color:var(--lo)}
/* Thumbnail picker */
.thumb-picker{margin-bottom:16px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;display:none}
.thumb-picker-tabs{display:flex;border-bottom:1px solid var(--border)}
.tp-tab{flex:1;padding:10px;font-size:12px;font-weight:600;color:var(--lo);text-align:center;cursor:pointer;transition:all .2s}
.tp-tab.active{color:var(--gold);border-bottom:2px solid var(--gold)}
.tp-panel{padding:12px;display:none}
.tp-panel.active{display:block}
.thumb-scrubber{width:100%;accent-color:var(--gold);margin:8px 0}
.thumb-scrubber-preview{width:100%;aspect-ratio:16/9;border-radius:6px;overflow:hidden;background:var(--bg2);position:relative;margin-bottom:8px}
.thumb-scrubber-preview canvas{width:100%;height:100%;object-fit:cover;display:block}
.btn-capture{width:100%;padding:9px;background:var(--gold);color:#000;border-radius:6px;font-size:13px;font-weight:700}
.thumb-upload-area{border:2px dashed var(--border);border-radius:8px;padding:20px;text-align:center;cursor:pointer;font-size:12px;color:var(--lo)}
.thumb-upload-area:hover{border-color:var(--gold);color:var(--gold)}
.upload-progress{
  height:4px;background:var(--border);border-radius:2px;
  overflow:hidden;margin-bottom:16px;display:none;
}
.upload-bar{height:100%;background:var(--gold);border-radius:2px;width:0%;transition:width .3s}
.form-field{margin-bottom:14px}
.form-field label{display:block;font-size:12px;font-weight:600;color:var(--mid);margin-bottom:5px}
.form-field input,.form-field textarea,.form-field select{
  width:100%;padding:11px 14px;background:var(--bg);border:1px solid var(--border);
  border-radius:var(--r);color:var(--hi);font-size:14px;outline:none;transition:border-color .2s;
}
.form-field input:focus,.form-field textarea:focus{border-color:var(--gold2)}
.form-field textarea{resize:vertical;min-height:80px}
.form-field select option{background:var(--bg)}
.btn-submit{
  width:100%;padding:13px;background:var(--gold);color:#000;border:none;
  border-radius:var(--r);font-size:14px;font-weight:700;transition:all .2s;
}
.btn-submit:disabled{opacity:.5;cursor:not-allowed}
.video-preview{
  width:100%;border-radius:var(--r);overflow:hidden;margin-bottom:16px;display:none;
  background:var(--bg2);aspect-ratio:16/9;
}
.video-preview video{width:100%;height:100%;object-fit:cover}

/* ═══ PROFILE SCREEN ═══ */
.profile-screen{padding:0}
.profile-header{
  padding:28px 16px 20px;
  background:linear-gradient(160deg,#1a1508,#0d0c07);
  border-bottom:1px solid var(--border);text-align:center;
}
.profile-avi-lg{
  width:80px;height:80px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:32px;font-weight:800;margin:0 auto 12px;
  border:3px solid var(--gold);
}
.profile-name{font-family:'Syne',sans-serif;font-size:22px;font-weight:800;color:var(--hi);margin-bottom:2px}
.profile-handle{font-size:13px;color:var(--lo);margin-bottom:12px}
.profile-stats{display:flex;gap:0;border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.p-stat{flex:1;text-align:center;padding:12px 8px}
.p-stat:not(:last-child){border-right:1px solid var(--border)}
.p-stat-n{font-family:'Syne',sans-serif;font-size:18px;font-weight:800;color:var(--hi)}
.p-stat-l{font-size:10px;color:var(--lo);text-transform:uppercase;letter-spacing:.8px}
.profile-videos{padding:16px}
.profile-vid-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}
.p-vid-thumb{aspect-ratio:3/4;border-radius:6px;overflow:hidden;cursor:pointer;position:relative}
.p-vid-thumb-bg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:24px}
.p-vid-views{position:absolute;bottom:4px;left:4px;font-size:10px;color:#fff;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.8)}

/* ═══ MODALS ═══ */
.overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(13,12,7,.88);backdrop-filter:blur(12px);
  display:flex;align-items:flex-end;
  opacity:0;pointer-events:none;transition:opacity .25s var(--ease);
}
.overlay.open{opacity:1;pointer-events:all}
.modal{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r2) var(--r2) 0 0;
  padding:20px 18px 32px;width:100%;
  transform:translateY(100%);transition:transform .3s var(--ease);
  max-height:92vh;overflow-y:auto;position:relative;
}
.overlay.open .modal{transform:translateY(0)}
.modal-handle{width:40px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 18px}
.modal-close{position:absolute;top:14px;right:14px;background:var(--bg);border:1px solid var(--border);color:var(--lo);width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px}
.modal-logo{font-family:'Syne',sans-serif;font-weight:800;font-size:19px;color:var(--hi);margin-bottom:3px}
.modal-logo span{color:var(--gold)}
.modal-sub{font-size:12px;color:var(--lo);margin-bottom:18px}
.auth-tabs{display:flex;background:var(--bg);border-radius:8px;padding:3px;margin-bottom:18px}
.auth-tab{flex:1;padding:8px;background:transparent;color:var(--lo);font-size:13px;font-weight:600;border-radius:6px;transition:all .2s}
.auth-tab.active{background:var(--card);color:var(--hi)}
.field{margin-bottom:13px}
.field label{display:block;font-size:12px;font-weight:600;color:var(--mid);margin-bottom:5px}
.field input{width:100%;padding:11px 14px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--hi);font-size:14px;outline:none;transition:border-color .2s}
.field input:focus{border-color:var(--gold2)}
.pass-wrap{position:relative}
.pass-wrap input{padding-right:44px}
.pass-eye{
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
  background:none;border:none;cursor:pointer;
  color:var(--lo);font-size:18px;line-height:1;padding:4px;
  transition:color .2s;user-select:none;-webkit-user-select:none;
}
.pass-eye:hover{color:var(--gold)}
.btn-auth{width:100%;padding:13px;background:var(--gold);color:#000;border:none;border-radius:var(--r);font-size:14px;font-weight:700;transition:all .2s;margin-top:4px}
.btn-auth:active{background:#f7b540}
.auth-note{font-size:11px;color:var(--lo);text-align:center;margin-top:12px}
.auth-note a{color:var(--gold)}

/* Premium modal */
.plan-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:14px 0}
.plan{padding:14px;border:1px solid var(--border);border-radius:var(--r);cursor:pointer}
.plan.rec{border-color:var(--gold);background:rgba(240,165,0,.06)}
.plan-name{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--lo);margin-bottom:4px}
.plan-price{font-family:'Syne',sans-serif;font-size:20px;font-weight:800;color:var(--hi)}
.plan-price span{font-size:11px;font-weight:400;color:var(--lo)}
.plan-perks{font-size:10px;color:var(--lo);margin-top:7px;line-height:1.6}
.rec-badge{display:inline-block;background:var(--gold);color:#000;font-size:8px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;padding:2px 7px;border-radius:2px;margin-bottom:5px}
.btn-pay{width:100%;padding:13px;background:var(--gold);color:#000;border:none;border-radius:var(--r);font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px}

/* Player modal */
.player-modal{max-width:100%;padding:0;background:var(--bg2)}
.player-screen{width:100%;aspect-ratio:16/9;background:var(--bg);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.player-vid{width:100%;height:100%;object-fit:contain;display:none}
.player-vid.show{display:block}
.player-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}
.player-bg-emoji{font-size:56px;opacity:.5}
.player-play-btn{
  width:64px;height:64px;border-radius:50%;
  background:rgba(240,165,0,.92);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:2;
  animation:pulse 2.5s ease infinite;
}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(240,165,0,.35)}70%{box-shadow:0 0 0 18px rgba(240,165,0,0)}100%{box-shadow:0 0 0 0 rgba(240,165,0,0)}}
.player-tag{position:absolute;top:10px;left:10px;z-index:2;background:var(--gold);color:#000;font-size:9px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;padding:3px 9px;border-radius:3px}
.player-info{padding:14px 16px 20px}
.player-title{font-family:'Syne',sans-serif;font-size:16px;font-weight:800;color:var(--hi);margin-bottom:8px}
.player-meta{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.player-stats{display:flex;gap:14px;font-size:12px;color:var(--lo)}
.player-actions{display:flex;gap:8px}
.p-action{
  flex:1;padding:10px;border:1px solid var(--border);border-radius:8px;
  color:var(--mid);font-size:12px;font-weight:600;
  display:flex;align-items:center;justify-content:center;gap:5px;transition:all .2s;
}
.p-action:active{border-color:var(--gold);color:var(--gold)}
.p-action.liked{background:rgba(240,165,0,.1);border-color:var(--gold);color:var(--gold)}

/* ═══ FOOTER ═══ */
footer{background:var(--bg2);border-top:1px solid var(--border);padding:24px 16px 16px}
.foot-logo{font-family:'Syne',sans-serif;font-weight:800;font-size:18px;color:var(--hi);margin-bottom:8px}
.foot-logo span{color:var(--gold)}
.foot-desc{font-size:12px;color:var(--lo);line-height:1.7;margin-bottom:14px}
.foot-bottom{border-top:1px solid var(--border);padding-top:12px;font-size:11px;color:var(--lo);text-align:center}

/* ═══ LOADING ═══ */
.loading{display:flex;align-items:center;justify-content:center;padding:40px;gap:8px;color:var(--lo);font-size:13px}
.spin{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ═══ TOAST ═══ */
.toast{
  position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--card);border:1px solid var(--border);color:var(--hi);
  padding:10px 20px;border-radius:var(--r);font-size:13px;font-weight:500;
  z-index:9999;transition:all .3s var(--ease);opacity:0;
  box-shadow:0 8px 28px rgba(0,0,0,.5);white-space:nowrap;pointer-events:none;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ═══ RESPONSIVE ═══ */
@media(min-width:600px){
  .vid-grid{grid-template-columns:repeat(3,1fr)}
  .live-card{width:300px}
}
@media(min-width:900px){
  body{padding-top:58px;padding-bottom:0}
  .botnav{display:none}
  .vid-grid{grid-template-columns:repeat(6,1fr)}
  .sec,.upload-screen,.profile-screen{max-width:1000px;margin:0 auto}
  .hero,.cat-bar,.tags-sec,.promo,.promo{max-width:none}
  .overlay{align-items:center;justify-content:center}
  .modal{border-radius:var(--r2);max-width:440px;transform:translateY(20px)}
}

/* ═══ TIKTOK FEED ═══ */
.tikfeed-overlay{
  position:fixed;inset:0;z-index:2000;background:#000;
  opacity:0;pointer-events:none;transition:opacity .2s var(--ease);
}
.tikfeed-overlay.open{opacity:1;pointer-events:all}
.tikfeed-close{
  position:absolute;top:16px;left:16px;z-index:20;
  background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.15);
  color:#fff;width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:17px;cursor:pointer;
}
.tik-mute-btn{
  position:absolute;top:16px;left:62px;z-index:20;
  background:rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.15);
  color:#fff;width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:17px;cursor:pointer;
}
.tik-progress{
  position:absolute;top:16px;right:16px;z-index:20;
  font-size:11px;color:rgba(255,255,255,.75);
  background:rgba(0,0,0,.45);padding:4px 11px;border-radius:20px;
}
.tikfeed-container{width:100%;height:100%;overflow:hidden;position:relative}
.tikfeed-track{
  display:flex;flex-direction:column;width:100%;
  transition:transform .38s cubic-bezier(.4,0,.2,1);
  will-change:transform;
}
.tikfeed-slide{
  width:100%;height:100dvh;flex-shrink:0;
  position:relative;overflow:hidden;background:#0a0a0a;
}
.tikfeed-slide video{width:100%;height:100%;object-fit:cover;display:block}
.tik-placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-size:90px;background:linear-gradient(160deg,#1a1508,#0d0c07,#0a100d);
}
.tik-info{
  position:absolute;left:0;right:70px;bottom:0;
  background:linear-gradient(transparent 0%,rgba(0,0,0,.88) 100%);
  padding:80px 16px 90px;z-index:5;pointer-events:none;
}
.tik-creator{
  font-size:15px;font-weight:700;color:#fff;margin-bottom:5px;
  display:flex;align-items:center;gap:6px;
}
.tik-creator-dot{width:8px;height:8px;background:var(--green);border-radius:50%}
.tik-title{font-size:13px;color:rgba(255,255,255,.85);line-height:1.5;margin-bottom:5px}
.tik-cat{font-size:12px;color:var(--gold);font-weight:600}
.tik-sidebar{
  position:absolute;right:12px;bottom:100px;
  display:flex;flex-direction:column;align-items:center;gap:12px;z-index:10;
}
.tik-btn{
  display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;
}
.tik-btn-ico{
  width:48px;height:48px;border-radius:50%;
  background:transparent;
  display:flex;align-items:center;justify-content:center;font-size:24px;
  transition:transform .18s;
  filter:drop-shadow(0 1px 3px rgba(0,0,0,.95)) drop-shadow(0 0 8px rgba(0,0,0,.6));
}
.tik-btn:active .tik-btn-ico{transform:scale(.88)}
.tik-btn span{font-size:11px;color:#fff;font-weight:700;text-shadow:0 1px 3px rgba(0,0,0,.95),0 0 6px rgba(0,0,0,.5);letter-spacing:.2px}
/* SVG icon colour — white by default */
.tik-ico-svg svg{color:#fff;stroke:#fff;transition:stroke .18s,fill .18s}
/* Liked state: gold heart fill */
.tik-btn.liked .tik-ico-svg svg{stroke:var(--gold);fill:var(--gold)}
.tik-btn.liked .tik-btn-ico{filter:drop-shadow(0 1px 3px rgba(240,165,0,.8)) drop-shadow(0 0 10px rgba(240,165,0,.4));transform:scale(1.08)}
.heart-burst{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%) scale(0);
  font-size:88px;pointer-events:none;z-index:15;
  animation:heartPop .85s ease forwards;
}
@keyframes heartPop{
  0%{transform:translate(-50%,-50%) scale(0);opacity:1}
  35%{transform:translate(-50%,-50%) scale(1.25);opacity:1}
  75%{transform:translate(-50%,-58%) scale(1.05);opacity:.85}
  100%{transform:translate(-50%,-68%) scale(.85);opacity:0}
}
.tik-tap-area{
  position:absolute;inset:0;z-index:4;
}
/* Swipe arrow indicators */
.tik-nav-hint{
  position:absolute;bottom:72px;left:50%;transform:translateX(-50%);
  color:rgba(255,255,255,.4);font-size:18px;z-index:5;
  animation:bobUp 2s ease infinite;pointer-events:none;
}
@keyframes bobUp{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-6px)}}
/* Thumbnail preview in upload */
.thumb-preview-wrap{
  margin-bottom:14px;border-radius:var(--r);overflow:hidden;display:none;
  position:relative;aspect-ratio:16/9;background:var(--bg2);
}
.thumb-preview-wrap img{width:100%;height:100%;object-fit:cover;display:block}
.thumb-preview-label{
  position:absolute;top:8px;left:8px;
  background:var(--gold);color:#000;font-size:10px;font-weight:800;
  padding:3px 8px;border-radius:4px;letter-spacing:.5px;
}
/* ═══ SEARCH ═══ */
.search-btn{
  width:34px;height:34px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;color:var(--mid);transition:color .2s;
  background:rgba(255,255,255,.04);border:1px solid var(--border);
}
.search-btn:hover{color:var(--gold)}
.search-overlay{
  position:fixed;inset:0;z-index:1800;background:rgba(0,0,0,.88);
  backdrop-filter:blur(12px);
  display:none;flex-direction:column;padding:16px;
}
.search-overlay.open{display:flex}
.search-bar{
  display:flex;align-items:center;gap:10px;margin-bottom:16px;
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r2);padding:0 14px;
}
.search-bar input{
  flex:1;background:none;border:none;outline:none;
  color:var(--hi);font-size:16px;padding:14px 0;
}
.search-bar input::placeholder{color:var(--lo)}
.search-close{font-size:20px;color:var(--mid);cursor:pointer;padding:4px}
.search-results{flex:1;overflow-y:auto}
.search-hint{
  color:var(--lo);font-size:13px;text-align:center;
  margin-top:60px;line-height:1.8;
}
.search-hint span{font-size:32px;display:block;margin-bottom:10px}
.search-result-item{
  display:flex;align-items:center;gap:12px;
  padding:12px 0;border-bottom:1px solid var(--border);cursor:pointer;
}
.search-result-item:active{opacity:.7}
.search-thumb{
  width:60px;height:80px;border-radius:8px;
  background:var(--card);overflow:hidden;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:24px;
}
.search-thumb img{width:100%;height:100%;object-fit:cover}
.search-result-info{flex:1;min-width:0}
.search-result-title{color:var(--hi);font-weight:600;font-size:13px;margin-bottom:3px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-result-creator{font-size:12px;color:var(--mid)}
.search-result-cat{font-size:11px;color:var(--gold);margin-top:2px}
/* ═══ LEGAL MODAL ═══ */
.legal-overlay{
  position:fixed;inset:0;z-index:1900;
  background:rgba(0,0,0,.92);
  display:none;flex-direction:column;
  overflow:hidden;
}
.legal-overlay.open{display:flex}
.legal-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 16px 0;flex-shrink:0;
}
.legal-title{font-family:'Syne',sans-serif;font-size:18px;font-weight:800;color:var(--hi)}
.legal-close{font-size:22px;color:var(--mid);cursor:pointer;padding:6px}
.legal-body{flex:1;overflow-y:auto;padding:16px}
.legal-body h2{color:var(--gold);font-size:14px;font-weight:700;margin:20px 0 8px;letter-spacing:.3px}
.legal-body h2:first-child{margin-top:0}
.legal-body p{color:var(--mid);font-size:13px;line-height:1.7;margin-bottom:10px}
.legal-body ul{color:var(--mid);font-size:13px;line-height:1.7;padding-left:18px;margin-bottom:10px}
.legal-body ul li{margin-bottom:4px}
.legal-body strong{color:var(--hi)}
.legal-badge{
  display:inline-block;background:var(--card);border:1px solid var(--border);
  font-size:10px;color:var(--gold);padding:3px 8px;border-radius:4px;
  margin-bottom:16px;letter-spacing:.5px;font-weight:700;
}
/* ═══ FOOTER ═══ */
.site-footer{
  padding:24px 16px 100px;border-top:1px solid var(--border);
  text-align:center;
}
.footer-links{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-bottom:8px}
.footer-links a{font-size:12px;color:var(--lo);cursor:pointer;transition:color .2s}
.footer-links a:hover{color:var(--gold)}
.footer-copy{font-size:11px;color:var(--lo);line-height:1.7}
/* ═══ COOKIE BANNER ═══ */
.cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:2500;
  background:var(--card);border-top:2px solid var(--gold);
  padding:14px 16px;display:none;
  animation:slideUpBanner .35s var(--ease);
}
.cookie-banner.show{display:block}
@keyframes slideUpBanner{from{transform:translateY(100%)}to{transform:translateY(0)}}
.cookie-inner{max-width:700px;margin:0 auto;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.cookie-text{flex:1;font-size:12px;color:var(--mid);line-height:1.6;min-width:200px}
.cookie-text a{color:var(--gold);text-decoration:underline;cursor:pointer}
.cookie-btns{display:flex;gap:8px;flex-shrink:0}
.cookie-accept{background:var(--gold);color:#000;font-weight:700;padding:8px 18px;border-radius:var(--r);font-size:12px}
.cookie-decline{background:transparent;border:1px solid var(--border);color:var(--mid);padding:8px 14px;border-radius:var(--r);font-size:12px}
/* ═══ COMMENTS PANEL ═══ */
.comments-panel{
  position:fixed;bottom:0;left:0;right:0;z-index:3000;
  background:var(--card);border-top:1px solid var(--border);
  border-radius:16px 16px 0 0;
  max-height:70vh;display:flex;flex-direction:column;
  transform:translateY(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);
  box-shadow:0 -8px 40px rgba(0,0,0,.6);
}
.comments-panel.open{transform:translateY(0)}
.comments-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0;
}
.comments-title{font-family:'Syne',sans-serif;font-size:15px;font-weight:800;color:var(--hi)}
.comments-close{font-size:20px;color:var(--mid);cursor:pointer;padding:4px}
.comments-list{flex:1;overflow-y:auto;padding:8px 0}
.comment-item{display:flex;gap:10px;padding:10px 16px;border-bottom:1px solid rgba(42,39,32,.5)}
.comment-avi{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.comment-body{flex:1}
.comment-name{font-size:12px;font-weight:700;color:var(--hi);margin-bottom:2px}
.comment-name[onclick],.comment-avi[onclick]{cursor:pointer}
.comment-name[onclick]:active{color:var(--gold)}
.comment-avi[onclick]:active{opacity:.7}
.comment-text{font-size:13px;color:var(--mid);line-height:1.5}
.comment-time{font-size:10px;color:var(--lo);margin-top:3px}
.comments-input{
  display:flex;align-items:center;gap:8px;
  padding:10px 12px;border-top:1px solid var(--border);flex-shrink:0;
  padding-bottom:calc(10px + env(safe-area-inset-bottom));
}
.comments-input input{
  flex:1;background:var(--bg);border:1px solid var(--border);
  border-radius:20px;padding:8px 14px;color:var(--hi);
  font-family:inherit;font-size:13px;outline:none;
}
.comments-input input::placeholder{color:var(--lo)}
.comments-input input:focus{border-color:var(--gold)}
.comment-send{
  width:34px;height:34px;border-radius:50%;
  background:var(--gold);color:#000;font-size:16px;font-weight:800;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.comment-send:disabled{opacity:.5}

#creatorOverlay{display:none;position:fixed;inset:0;z-index:999;overflow-y:auto;background:var(--bg,#111008);flex-direction:column}
#creatorOverlay.open{display:flex}
#creatorOverlay .modal{width:100%;max-width:100%;min-height:100vh;border-radius:0;margin:0;padding-top:60px}

/* ═══════════════════════════════════════
   kwayv DESIGN UPGRADES — African Soul
═══════════════════════════════════════ */

/* Sticky vibe bar (upgrades .cat-bar) */
.cat-bar{
  position:sticky;top:var(--nav);z-index:50;
  background:rgba(10,8,3,0.97);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}
.cat-pill{
  padding:7px 14px;border-radius:24px;border:1.5px solid var(--border);
  background:transparent;color:var(--lo);font-size:11px;font-weight:600;
  white-space:nowrap;display:inline-flex;align-items:center;gap:5px;
  transition:all .25s var(--ease);cursor:pointer;flex-shrink:0;
}
.cat-pill:hover{border-color:var(--gold2);color:var(--gold)}
.cat-pill.active{
  background:var(--gold);border-color:var(--gold);color:#000;
  box-shadow:0 4px 16px rgba(212,165,46,0.25);
}

/* Fire animations */
@keyframes fire-flicker{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
@keyframes wave-pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:0.8}}
@keyframes live-dot{0%,100%{opacity:1}50%{opacity:0.4}}
@keyframes live-ring{
  0%{box-shadow:0 0 0 0 rgba(232,93,93,0.4)}
  70%{box-shadow:0 0 0 6px rgba(232,93,93,0)}
  100%{box-shadow:0 0 0 0 rgba(232,93,93,0)}
}

/* Real vid cards — hover play button */
.real-vid-card{position:relative;overflow:hidden;border-radius:var(--r2);cursor:pointer;background:var(--card);border:1px solid var(--border);transition:transform .25s var(--ease),box-shadow .3s,border-color .25s}
.real-vid-card:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,0.35);border-color:var(--border-warm)}
.real-vid-card:active{transform:scale(0.97)}
.real-vid-card .vid-play-btn{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:40px;height:40px;border-radius:50%;
  background:rgba(212,165,46,0.9);color:#000;
  display:flex;align-items:center;justify-content:center;font-size:16px;
  opacity:0;transition:opacity .3s,transform .3s var(--ease-bounce);z-index:3;
}
.real-vid-card:hover .vid-play-btn{opacity:1;transform:translate(-50%,-50%) scale(1.05)}

/* River sort tabs (Fresh / Fire / Ancestor) */
.river-sort{display:flex;gap:3px;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:3px}
.river-sort-btn{padding:4px 10px;border-radius:6px;font-size:10px;font-weight:600;color:var(--lo);background:none;border:none;cursor:pointer;transition:all .2s}
.river-sort-btn.active{background:var(--gold);color:#000}

/* Hot Right Now strip */
.hot-strip{padding:18px 0 12px;border-bottom:1px solid var(--border)}
.hot-head{display:flex;align-items:baseline;gap:8px;padding:0 16px;margin-bottom:12px}
.hot-title{font-family:'Syne',sans-serif;font-size:16px;font-weight:800;color:var(--hi);display:flex;align-items:center;gap:6px}
.hot-fire{font-size:18px;animation:fire-flicker 1.2s ease infinite}
.hot-scroll{display:flex;gap:10px;overflow-x:auto;padding:0 16px;scrollbar-width:none;padding-bottom:4px}
.hot-scroll::-webkit-scrollbar{display:none}
.hot-card{flex-shrink:0;width:140px;border-radius:var(--r2);overflow:hidden;cursor:pointer;position:relative;background:var(--card);border:1px solid var(--border);transition:transform .25s var(--ease)}
.hot-card:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(0,0,0,0.4)}
.hot-card:active{transform:scale(0.97)}
.hot-thumb{aspect-ratio:3/4;position:relative;overflow:hidden}
.hot-thumb img{width:100%;height:100%;object-fit:cover}
.hot-thumb-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:32px;background:linear-gradient(160deg,#1a1508,#0d0c07)}
.hot-overlay{position:absolute;inset:0;background:linear-gradient(transparent 30%,rgba(10,8,3,0.9) 100%);pointer-events:none}
.hot-info{position:absolute;bottom:0;left:0;right:0;padding:8px}
.hot-creator{font-size:10px;font-weight:700;color:var(--hi);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hot-views{font-size:9px;color:var(--lo)}
.hot-rank{position:absolute;top:6px;left:6px;background:var(--gold);color:#000;font-size:9px;font-weight:800;padding:2px 6px;border-radius:4px}

/* Soul hero upgrades */
.hero{background:radial-gradient(ellipse 80% 60% at 20% 30%,rgba(212,165,46,0.08),transparent 55%),radial-gradient(ellipse 60% 50% at 80% 70%,rgba(62,207,142,0.04),transparent 45%),linear-gradient(160deg,#14100a,#0a0803)}
.hero-h1{letter-spacing:-1.5px}
.hero-h1 em{position:relative}
.hero-h1 em::after{content:'';position:absolute;bottom:2px;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--gold2),transparent);opacity:0.4;border-radius:3px}

/* The Circle — creators */
.circle-section{padding:16px}
.circle-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.circle-title{font-family:'Syne',sans-serif;font-size:16px;font-weight:800;color:var(--hi);display:flex;align-items:center;gap:8px}
.circle-wave{width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--green));animation:wave-pulse 2s ease infinite;flex-shrink:0}

/* Infinite scroll sentinel */
#feedSentinel{padding:8px 0}

/* Feed section header with sort */
.feed-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px}
.feed-title{font-family:'Syne',sans-serif;font-size:16px;font-weight:800;color:var(--hi);display:flex;align-items:center;gap:8px}
.feed-wave{display:inline-block;animation:wave-pulse 2s ease infinite}
