/* ═══════════════════════════════════════════════
   STUDY MATERIAL — Main Stylesheet
   Theme: Blood Red Venom
   ═══════════════════════════════════════════════ */

:root {
  --bg:#060000;
  --surface:#0e0101;
  --surface-2:#130202;
  --surface-3:#190303;
  --border:#291313;
  --border-2:#2a0505;
  --accent:#ff1a1a;
  --accent2:#ff4500;
  --grad:linear-gradient(135deg,#ff1a1a,#cc0000);
  --disk-accent:#3b82f6;
  --disk-grad:linear-gradient(135deg,#2563eb,#4f46e5);
  --premium-accent:#f59e0b;
  --premium-grad:linear-gradient(135deg,#d97706,#b91c1c);
  --promo-accent:#a855f7;
  --promo-grad:linear-gradient(135deg,#7c3aed,#be185d);
  --text:#f5eded;
  --text-2:#8a7070;
  --text-3:#d08080;
  --online:#22c55e;
  --like:#22c55e;
  --dislike:#f87171;
  --radius:12px;
  --nav-h:58px;
  --sidebar-w:224px;
  --font-brand:'Bebas Neue',Impact,sans-serif;
  --font-body:'DM Sans',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);min-height:100vh;overflow-x:hidden;}

/* ══ LOADING BAR ══ */
#loading-bar{position:fixed;top:0;left:0;height:2px;width:0%;background:var(--grad);z-index:9999;transition:width .22s ease,opacity .35s ease;}
#loading-bar.done{width:100%!important;opacity:0;}

/* ══ ANIMATIONS ══ */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pageIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
@keyframes sheetUp{from{transform:translateY(22px);opacity:0}to{transform:none;opacity:1}}
@keyframes slideInRight{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:none}}
@keyframes likePop{0%{transform:scale(1)}40%{transform:scale(1.35)}70%{transform:scale(.9)}100%{transform:scale(1)}}
@keyframes spinOnce{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes notifSlide{from{opacity:0;transform:translateX(120%)}to{opacity:1;transform:translateX(0)}}
@keyframes notifOut{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(120%)}}
@keyframes goldPulse{0%,100%{box-shadow:0 0 0 0 rgba(245,158,11,.4)}50%{box-shadow:0 0 0 8px rgba(245,158,11,0)}}
@keyframes promoPulse{0%,100%{opacity:1}50%{opacity:.7}}
@keyframes ageFadeIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
@keyframes ageShake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-8px)}40%,80%{transform:translateX(8px)}}
@keyframes qrSpin{to{transform:rotate(360deg)}}
@keyframes premiumGlow{0%,100%{box-shadow:0 0 20px rgba(245,158,11,.2)}50%{box-shadow:0 0 40px rgba(245,158,11,.5)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes scanLine{0%{top:0%}100%{top:100%}}
@keyframes lockPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
@keyframes venomPulse{0%,100%{box-shadow:0 0 0 0 rgba(255,26,26,.4)}50%{box-shadow:0 0 0 8px rgba(255,26,26,0)}}
@keyframes bloodDrip{0%{transform:scaleY(0);opacity:0}60%{transform:scaleY(1.1);opacity:1}100%{transform:scaleY(1);opacity:1}}
@keyframes countUp{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ═══════════════════════════════════════════
   AGE VERIFICATION OVERLAY
   ═══════════════════════════════════════════ */
#age-gate{
  position:fixed;inset:0;z-index:99999;
  background:radial-gradient(ellipse at 50% 30%,#1a0000 0%,#0a0000 40%,#030000 100%);
  display:flex;align-items:center;justify-content:center;padding:20px;
}
#age-gate.hiding{animation:ageFadeIn .4s ease reverse forwards;pointer-events:none;}
.age-box{
  background:linear-gradient(145deg,rgba(255,26,26,.06),rgba(204,0,0,.03));
  border:1px solid rgba(255,26,26,.25);border-radius:20px;
  padding:clamp(28px,6vw,48px) clamp(24px,5vw,44px);
  max-width:440px;width:100%;text-align:center;
  animation:ageFadeIn .5s ease;position:relative;overflow:hidden;
}
.age-box::before{content:'';position:absolute;top:-1px;left:10%;right:10%;height:2px;background:var(--grad);border-radius:0 0 4px 4px;}
.age-box::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% -20%,rgba(255,26,26,.08) 0%,transparent 70%);pointer-events:none;}
.age-warning-icon{font-size:clamp(40px,10vw,64px);display:block;margin-bottom:16px;animation:float 3s ease infinite;}
.age-title{font-family:var(--font-brand);font-size:clamp(26px,7vw,38px);letter-spacing:2px;color:#fff;margin-bottom:8px;line-height:1;}
.age-title span{color:var(--accent);}
.age-subtitle{font-size:clamp(11px,3vw,13px);color:var(--text-2);line-height:1.6;margin-bottom:28px;}
.age-subtitle strong{color:var(--text);}
.age-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}
.age-btn-yes{flex:1;min-width:130px;max-width:180px;background:var(--grad);border:none;color:#fff;font-family:var(--font-brand);font-size:16px;letter-spacing:1px;padding:14px 24px;border-radius:10px;cursor:pointer;transition:transform .14s,box-shadow .14s;box-shadow:0 4px 20px rgba(255,26,26,.3);}
.age-btn-yes:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,26,26,.5);}
.age-btn-no{flex:1;min-width:130px;max-width:180px;background:transparent;border:1px solid var(--border-2);color:var(--text-2);font-family:var(--font-brand);font-size:16px;letter-spacing:1px;padding:14px 24px;border-radius:10px;cursor:pointer;transition:background .14s,color .14s;}
.age-btn-no:hover{background:var(--surface-2);color:var(--text);}
.age-legal{font-size:10px;color:var(--text-3);line-height:1.5;margin-top:20px;padding-top:16px;border-top:1px solid var(--border);}
.age-scan-line{position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,26,26,.4),transparent);animation:scanLine 3s linear infinite;pointer-events:none;}
.age-shake{animation:ageShake .4s ease !important;}
.age-denied{position:fixed;inset:0;z-index:100000;background:#020000;display:none;align-items:center;justify-content:center;text-align:center;padding:40px;}
.age-denied.show{display:flex;flex-direction:column;gap:16px;}
.age-denied-icon{font-size:64px;}
.age-denied h2{font-family:var(--font-brand);font-size:28px;color:var(--text-3);}
.age-denied p{font-size:13px;color:var(--text-3);max-width:300px;}

/* ═══════════════════════════════════════════
   LAYOUT
   ═══════════════════════════════════════════ */
@media(min-width:900px){
  body{display:flex;}
  #sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);background:rgba(6,0,0,.98);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:300;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent;}
  #sidebar::-webkit-scrollbar{width:3px;}
  #sidebar::-webkit-scrollbar-thumb{background:var(--border);}
  #main-wrap{margin-left:var(--sidebar-w);flex:1;min-height:100vh;width:calc(100% - var(--sidebar-w));}
  nav{display:none!important;}
  body{padding-bottom:0;}
}
@media(max-width:899px){
  #sidebar{display:none;}
  body{padding-bottom:calc(var(--nav-h) + 4px);}
  #main-wrap{min-height:100vh;}
}

/* ══ SIDEBAR ══ */
.sb-logo{padding:18px 16px 14px;border-bottom:1px solid var(--border);display:flex;align-items:baseline;}
.sb-logo .wrd{font-family:var(--font-brand);font-size:26px;letter-spacing:2px;color:#fff;}
.sb-logo .ext{font-family:var(--font-brand);font-size:26px;letter-spacing:2px;color:var(--accent);}
.sb-online{display:flex;align-items:center;gap:6px;padding:9px 16px;font-size:11px;color:var(--online);font-weight:500;border-bottom:1px solid var(--border);}
.sb-online-dot{width:6px;height:6px;border-radius:50%;background:var(--online);box-shadow:0 0 5px var(--online);animation:pulse 2s infinite;}
.sb-stats{display:flex;flex-direction:column;border-bottom:1px solid var(--border);padding:12px 16px;gap:9px;}
.sb-stat{display:flex;align-items:center;justify-content:space-between;}
.sb-stat-lbl{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;}
.sb-stat-val{font-family:var(--font-brand);font-size:20px;color:var(--accent);}

/* ── Sidebar auth widget ── */
.sb-auth{padding:10px;border-bottom:1px solid var(--border);}
.sb-user-chip{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--border-2);border-radius:8px;padding:9px 11px;}
.sb-user-avatar{width:28px;height:28px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0;}
.sb-user-name{font-size:12px;font-weight:500;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sb-user-badge{font-family:var(--font-brand);font-size:9px;letter-spacing:.5px;padding:2px 7px;border-radius:3px;flex-shrink:0;}
.sb-user-badge.premium{background:rgba(245,158,11,.18);border:1px solid rgba(245,158,11,.35);color:var(--premium-accent);}
.sb-user-badge.free{background:rgba(255,255,255,.06);border:1px solid var(--border-2);color:var(--text-3);}
.sb-logout-btn{margin-top:6px;width:100%;background:none;border:1px solid var(--border-2);color:var(--text-3);font-family:var(--font-brand);font-size:11px;letter-spacing:.4px;padding:6px;border-radius:6px;cursor:pointer;transition:all .14s;}
.sb-logout-btn:hover{border-color:rgba(255,26,26,.3);color:var(--accent);}
.sb-login-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;background:rgba(255,255,255,.04);border:1px solid var(--border-2);border-radius:8px;padding:10px;cursor:pointer;font-family:var(--font-brand);font-size:12px;letter-spacing:.5px;color:var(--text-2);transition:all .14s;}
.sb-login-btn:hover{background:rgba(255,255,255,.08);color:var(--text);}
.sb-login-btn svg{width:16px;height:16px;fill:#229ED9;}

.sb-nav{padding:10px;display:flex;flex-direction:column;gap:3px;border-bottom:1px solid var(--border);}
.sb-nav-btn{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:7px;cursor:pointer;border:none;background:transparent;font-family:var(--font-brand);font-size:15px;letter-spacing:.5px;color:var(--text-2);transition:background .14s,color .14s;width:100%;text-align:left;}
.sb-nav-btn svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.8;flex-shrink:0;}
.sb-nav-btn:hover{background:var(--surface-2);color:var(--text);}
.sb-nav-btn.active{background:rgba(255,26,26,.1);color:var(--accent);}
.sb-nav-btn.disk-btn.active{background:rgba(59,130,246,.1);color:var(--disk-accent);}
.sb-nav-btn.premium-btn.active{background:rgba(245,158,11,.1);color:var(--premium-accent);}
.sb-tags{padding:10px;display:flex;flex-direction:column;gap:3px;}
.sb-tag{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:7px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text-2);transition:background .14s,color .14s;user-select:none;}
.sb-tag:hover{background:var(--surface-2);color:var(--text);}
.sb-tag.active{background:rgba(255,26,26,.1);color:var(--accent);}
.sb-tag-icon{font-size:14px;}
.sb-tag-count{margin-left:auto;background:rgba(255,26,26,.12);color:var(--accent);font-family:var(--font-brand);font-size:12px;padding:1px 8px;border-radius:4px;transition:background .14s;}
.sb-tag.active .sb-tag-count{background:rgba(255,26,26,.25);}
.sb-ad{margin:12px 10px 10px;background:linear-gradient(135deg,rgba(255,26,26,.1),rgba(204,0,0,.04));border:1px solid rgba(255,26,26,.18);border-radius:var(--radius);padding:14px 12px;text-decoration:none;display:block;transition:border-color .18s;}
.sb-ad:hover{border-color:rgba(255,26,26,.42);}
.sb-ad-title{font-family:var(--font-brand);font-size:16px;color:#fff;letter-spacing:.5px;}
.sb-ad-sub{font-size:11px;color:var(--text-2);margin-top:3px;}
.sb-ad-btn{margin-top:10px;display:block;width:100%;text-align:center;background:var(--grad);color:#fff;font-family:var(--font-brand);font-size:14px;letter-spacing:.5px;padding:9px;border-radius:6px;}
.sb-notif-btn{margin:8px 10px 0;display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:7px;cursor:pointer;border:1px solid var(--border-2);background:var(--surface-2);font-family:var(--font-brand);font-size:13px;letter-spacing:.4px;color:var(--text-2);transition:all .14s;width:calc(100% - 20px);}
.sb-notif-btn:hover{border-color:#2a0808;color:var(--text);}
.sb-notif-btn.enabled{background:rgba(34,197,94,.08);border-color:rgba(34,197,94,.25);color:var(--online);}
.sb-notif-btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.8;flex-shrink:0;}
.sb-credit{padding:10px 16px 14px;margin-top:auto;border-top:1px solid var(--border);font-size:10px;color:var(--text-3);letter-spacing:.08em;text-align:center;}
.sb-credit a{color:var(--accent);text-decoration:none;font-family:var(--font-brand);font-size:11px;letter-spacing:.5px;}

/* ══ MOBILE TOPBAR ══ */
#topbar{position:sticky;top:0;z-index:200;background:rgba(6,0,0,.97);border-bottom:1px solid var(--border);backdrop-filter:blur(14px);}
.topbar-row1{display:flex;align-items:center;justify-content:space-between;padding:10px 14px 0;gap:10px;}
.mob-logo{font-family:var(--font-brand);font-size:22px;letter-spacing:2px;text-decoration:none;flex-shrink:0;color:#fff;}
.mob-logo .ext{color:var(--accent);}
.online-pill{display:flex;align-items:center;gap:5px;background:rgba(34,197,94,.07);border:1px solid rgba(34,197,94,.18);border-radius:30px;padding:4px 10px;font-size:11px;font-weight:500;color:var(--online);flex-shrink:0;}
.online-dot{width:6px;height:6px;border-radius:50%;background:var(--online);box-shadow:0 0 5px var(--online);animation:pulse 2s infinite;}

/* ── Mob auth chip (topbar) ── */
.mob-auth-chip{display:flex;align-items:center;gap:6px;background:var(--surface-2);border:1px solid var(--border-2);border-radius:20px;padding:4px 10px 4px 4px;cursor:pointer;transition:border-color .14s;}
.mob-auth-chip:hover{border-color:#2a0808;}
.mob-auth-avatar{width:24px;height:24px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;}
.mob-auth-name{font-size:11px;color:var(--text);font-weight:500;max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.mob-auth-badge{font-family:var(--font-brand);font-size:9px;color:var(--premium-accent);}
.mob-login-btn{display:flex;align-items:center;gap:5px;background:rgba(255,255,255,.05);border:1px solid var(--border-2);border-radius:20px;padding:5px 10px;font-family:var(--font-brand);font-size:11px;letter-spacing:.4px;color:var(--text-2);cursor:pointer;transition:all .14s;}
.mob-login-btn:hover{color:var(--text);border-color:#2a0808;}
.mob-login-btn svg{width:14px;height:14px;fill:#229ED9;}

.search-row{padding:9px 14px 8px;}
.search-wrap{position:relative;display:flex;align-items:center;}
.search-wrap svg{position:absolute;left:10px;width:15px;height:15px;stroke:var(--text-3);fill:none;stroke-width:2;pointer-events:none;}
#search-input{width:100%;background:var(--surface-2);border:1px solid var(--border-2);border-radius:8px;color:var(--text);font-family:var(--font-body);font-size:13px;padding:9px 34px 9px 34px;outline:none;transition:border-color .18s;}
#search-input::placeholder{color:var(--text-3);}
#search-input:focus{border-color:#2a0808;}
#search-clear{position:absolute;right:10px;background:none;border:none;cursor:pointer;color:var(--text-3);font-size:14px;padding:4px;display:none;}
#mob-filter-bar{display:flex;gap:5px;overflow-x:auto;padding:0 14px 10px;scrollbar-width:none;}
#mob-filter-bar::-webkit-scrollbar{display:none;}
.tag{flex-shrink:0;display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:6px;font-family:var(--font-brand);font-size:12px;letter-spacing:.4px;cursor:pointer;border:1px solid var(--border-2);background:var(--surface-2);color:var(--text-2);transition:all .14s;user-select:none;position:relative;overflow:hidden;}
.tag::before{content:'';position:absolute;inset:0;background:var(--grad);opacity:0;transition:opacity .14s;}
.tag>*{position:relative;z-index:1;}
.tag.active{border-color:transparent;color:#fff;box-shadow:0 2px 12px rgba(255,26,26,.28);}
.tag.active::before{opacity:1;}
.tag-badge{background:rgba(255,26,26,.12);color:var(--accent);font-size:10px;font-weight:700;padding:1px 6px;border-radius:3px;min-width:18px;text-align:center;}
.tag.active .tag-badge{background:rgba(255,255,255,.2);color:#fff;}
@media(min-width:900px){#topbar{display:none!important;}}

/* ══ DESKTOP TOPBAR ══ */
#desktop-topbar{position:sticky;top:0;z-index:100;background:rgba(6,0,0,.97);border-bottom:1px solid var(--border);backdrop-filter:blur(14px);padding:11px 16px;display:flex;align-items:center;gap:12px;}
.d-search-wrap{flex:1;max-width:420px;position:relative;display:flex;align-items:center;}
.d-search-wrap svg{position:absolute;left:10px;width:14px;height:14px;stroke:var(--text-3);fill:none;stroke-width:2;pointer-events:none;}
#desktop-search{width:100%;background:var(--surface-2);border:1px solid var(--border-2);border-radius:8px;color:var(--text);font-family:var(--font-body);font-size:13px;padding:8px 32px 8px 32px;outline:none;transition:border-color .18s;}
#desktop-search::placeholder{color:var(--text-3);}
#desktop-search:focus{border-color:#2a0808;}
#desktop-search-clear{position:absolute;right:9px;background:none;border:none;cursor:pointer;color:var(--text-3);font-size:13px;padding:4px;display:none;}
.d-tags{display:flex;gap:6px;margin-left:auto;}
.d-tag{display:flex;align-items:center;gap:5px;padding:6px 13px;border-radius:6px;font-family:var(--font-brand);font-size:12px;letter-spacing:.4px;cursor:pointer;border:1px solid var(--border-2);background:var(--surface-2);color:var(--text-2);transition:all .14s;user-select:none;position:relative;overflow:hidden;}
.d-tag::before{content:'';position:absolute;inset:0;background:var(--grad);opacity:0;transition:opacity .14s;}
.d-tag>*{position:relative;z-index:1;}
.d-tag.active{border-color:transparent;color:#fff;box-shadow:0 2px 10px rgba(255,26,26,.25);}
.d-tag.active::before{opacity:1;}
.d-tag-badge{background:rgba(255,26,26,.12);color:var(--accent);font-size:10px;font-weight:700;padding:1px 5px;border-radius:3px;min-width:16px;text-align:center;}
.d-tag.active .d-tag-badge{background:rgba(255,255,255,.2);color:#fff;}
@media(max-width:899px){#desktop-topbar{display:none!important;}}

/* ══ STATS BAR ══ */
.stats-bar{display:flex;border-bottom:1px solid var(--border);}
.stat-item{flex:1;text-align:center;padding:9px 6px;border-right:1px solid var(--border);}
.stat-item:last-child{border-right:none;}
.stat-num{font-family:var(--font-brand);font-size:18px;color:var(--accent);}
.stat-lbl{font-size:9px;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin-top:1px;}
@media(min-width:900px){.stats-bar{display:none;}}

/* ══ AD BANNER ══ */
.ad-banner{margin:8px 10px;background:var(--surface-2);border:1px solid var(--border-2);border-radius:var(--radius);padding:10px 12px;display:flex;align-items:center;gap:10px;text-decoration:none;position:relative;overflow:hidden;min-height:56px;transition:border-color .18s;}
.ad-banner:hover{border-color:#2a0808;}
.ad-banner::before{content:'AD';position:absolute;top:4px;right:6px;font-size:9px;color:var(--text-3);letter-spacing:.1em;}
.ad-icon{width:36px;height:36px;border-radius:6px;background:var(--grad);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:17px;}
.ad-text .ad-title{font-size:13px;font-weight:600;color:var(--text);}
.ad-text .ad-sub{font-size:11px;color:var(--text-2);margin-top:2px;}
.ad-cta{margin-left:auto;flex-shrink:0;background:var(--grad);color:#fff;font-size:11px;font-weight:700;padding:6px 12px;border-radius:5px;white-space:nowrap;}

/* ══ SECTION LABEL ══ */
.section-label{font-family:var(--font-brand);font-size:13px;letter-spacing:1.5px;color:var(--text-3);text-transform:uppercase;padding:11px 12px 7px;display:flex;align-items:center;gap:8px;}
.section-label::after{content:'';flex:1;height:1px;background:var(--border);}
.filter-info{display:none;padding:2px 14px 8px;font-size:11px;color:var(--text-3);}
.filter-info.visible{display:block;}
.filter-info strong{color:var(--accent);font-family:var(--font-brand);}

/* ══ VIDEOS SECTION HEADER ══ */
.vid-section-head{display:flex;align-items:center;padding:8px 12px 6px;gap:8px;}
.vid-section-label{font-family:var(--font-brand);font-size:13px;letter-spacing:1.5px;color:var(--text-3);text-transform:uppercase;display:flex;align-items:center;gap:8px;flex:1;}
.vid-section-label::after{content:'';flex:1;height:1px;background:var(--border);}
.refresh-btn{display:flex;align-items:center;gap:5px;background:var(--surface-2);border:1px solid var(--border-2);border-radius:6px;padding:5px 11px;font-family:var(--font-brand);font-size:11px;letter-spacing:.4px;color:var(--text-2);cursor:pointer;transition:all .14s;flex-shrink:0;}
.refresh-btn:hover{border-color:#2a0808;color:var(--text);}
.refresh-btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;}
.refresh-btn.spinning svg{animation:spinOnce .5s linear;}

/* ══ FEED GRID ══ */
#home-feed,#videos-feed,#disk-feed{padding:0 8px 16px;display:grid;grid-template-columns:repeat(2,1fr);gap:8px;}
#home-feed .state-msg,#home-feed #load-sentinel,#home-feed #scroll-end,#home-feed .feed-ad,#home-feed .spinner,
#videos-feed .state-msg,#videos-feed #v-load-sentinel,#videos-feed #v-scroll-end,#videos-feed .spinner,
#disk-feed .state-msg,#disk-feed #d-load-sentinel,#disk-feed #d-scroll-end,#disk-feed .spinner{grid-column:1/-1;}
#home-feed .promo-feed-card,#videos-feed .promo-feed-card{grid-column:1/-1;}
@media(min-width:600px) and (max-width:899px){#home-feed,#videos-feed,#disk-feed{grid-template-columns:repeat(3,1fr);padding:0 12px 20px;}}
@media(min-width:900px){#home-feed,#videos-feed,#disk-feed{grid-template-columns:repeat(3,1fr);padding:0 16px 24px;}}
@media(min-width:1200px){#home-feed,#videos-feed,#disk-feed{grid-template-columns:repeat(4,1fr);}}
@media(min-width:1600px){#home-feed,#videos-feed,#disk-feed{grid-template-columns:repeat(5,1fr);}}

/* ══ CARD ══ */
.card{background:var(--surface);border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);cursor:pointer;display:flex;flex-direction:column;animation:fadeUp .26s ease both;transition:border-color .16s,transform .16s,box-shadow .16s;position:relative;}
.card:hover{border-color:#2a0808;transform:translateY(-3px);box-shadow:0 12px 32px rgba(0,0,0,.7),0 0 20px rgba(255,26,26,.06);}
.card:active{transform:scale(.97);}
.img-wrap{position:relative;width:100%;aspect-ratio:16/9;background:var(--surface-2);overflow:hidden;border-radius:var(--radius) var(--radius) 0 0;}
.img-wrap.shimmer::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.035) 50%,transparent 100%);background-size:200% 100%;animation:shimmer 1.1s infinite;}
.img-wrap.img-done::before{display:none;}
.img-wrap img{width:100%;height:100%;object-fit:cover;display:block;opacity:0;transition:opacity .22s,transform .28s;}
.img-wrap img.visible{opacity:1;}
.card:hover .img-wrap img.visible{transform:scale(1.04);}
.img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.65) 0%,transparent 55%);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .16s;}
.card:hover .img-overlay{opacity:1;}
.play-btn{width:40px;height:40px;border-radius:50%;background:rgba(255,26,26,.9);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(255,26,26,.5);transition:transform .14s;}
.play-btn:hover{transform:scale(1.1);}
.play-btn svg{width:14px;height:14px;fill:#fff;margin-left:2px;}
.no-preview{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-3);font-size:10px;gap:6px;}
.no-preview svg{width:22px;height:22px;stroke:var(--text-3);fill:none;stroke-width:1.5;}
.new-badge{position:absolute;top:7px;left:7px;background:var(--accent);color:#fff;font-family:var(--font-brand);font-size:9px;letter-spacing:.5px;padding:2px 7px;border-radius:4px;}
.hd-badge{position:absolute;top:7px;right:7px;background:rgba(255,69,0,.9);color:#fff;font-family:var(--font-brand);font-size:9px;padding:2px 7px;border-radius:4px;}
.vid-badge{position:absolute;top:7px;left:7px;background:rgba(255,26,26,.85);color:#fff;font-family:var(--font-brand);font-size:9px;padding:2px 7px;border-radius:4px;}
.album-badge{position:absolute;top:7px;left:7px;background:rgba(99,102,241,.9);color:#fff;font-family:var(--font-brand);font-size:9px;padding:2px 7px;border-radius:4px;z-index:2;}
.dur-float{position:absolute;bottom:7px;right:7px;background:rgba(0,0,0,.8);color:#fff;font-family:var(--font-brand);font-size:10px;padding:2px 7px;border-radius:4px;backdrop-filter:blur(4px);}
.share-btn{position:absolute;bottom:7px;right:7px;width:28px;height:28px;border-radius:50%;background:rgba(0,0,0,.72);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .16s,background .14s;cursor:pointer;z-index:10;}
.share-btn svg{width:12px;height:12px;stroke:#fff;fill:none;stroke-width:2;}
.card:hover .share-btn{opacity:1;}
.share-btn:hover{background:rgba(255,26,26,.85)!important;}

/* ── Premium lock overlay on video card ── */
.premium-lock-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(0,0,0,.75),rgba(245,158,11,.12));
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  border-radius:var(--radius) var(--radius) 0 0;
  z-index:5;
}
.premium-lock-overlay svg{width:28px;height:28px;stroke:#f59e0b;fill:none;stroke-width:1.8;animation:lockPulse 2s ease infinite;}
.premium-lock-overlay span{font-family:var(--font-brand);font-size:10px;letter-spacing:.8px;color:#f59e0b;background:rgba(245,158,11,.15);border:1px solid rgba(245,158,11,.3);padding:2px 10px;border-radius:4px;}
.card-premium-pill{
  display:inline-flex;align-items:center;gap:3px;
  background:rgba(245,158,11,.15);border:1px solid rgba(245,158,11,.3);
  color:var(--premium-accent);font-family:var(--font-brand);font-size:9px;letter-spacing:.5px;
  padding:2px 7px;border-radius:4px;margin-top:3px;width:fit-content;
}

#copy-toast{position:fixed;bottom:72px;left:50%;transform:translateX(-50%) translateY(8px);background:var(--surface-3);border:1px solid var(--border-2);color:var(--text);font-size:12px;font-family:var(--font-body);padding:8px 16px;border-radius:8px;opacity:0;pointer-events:none;transition:opacity .18s,transform .18s;z-index:9000;white-space:nowrap;}
#copy-toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
@media(min-width:900px){#copy-toast{bottom:24px;}}
.card-info{padding:9px 10px 11px;flex:1;display:flex;flex-direction:column;gap:4px;}
.card-title{font-size:12px;font-weight:500;line-height:1.45;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.card-meta{font-size:10px;color:var(--text-3);margin-top:auto;display:flex;align-items:center;gap:4px;flex-wrap:wrap;}
.dur-badge{background:var(--surface-3);padding:1px 5px;border-radius:3px;font-size:9px;color:var(--text-2);}

/* ══ VIDEO VIEWS BADGE ══ */
.views-badge{
  display:inline-flex;align-items:center;gap:3px;
  font-family:var(--font-brand);font-size:10px;
  color:var(--text-3);letter-spacing:.2px;
  animation:countUp .3s ease;
}
.views-badge svg{width:10px;height:10px;stroke:currentColor;fill:none;stroke-width:2;flex-shrink:0;}
.views-badge.hot{color:#ff6b35;}
.views-badge.trending{color:var(--accent);}

/* Views on player page */
.nf-views-row{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-brand);font-size:13px;
  color:var(--text-2);letter-spacing:.3px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border-2);
  border-radius:6px;
  padding:4px 10px;
}
.nf-views-row svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;}
.nf-views-row.hot-views{color:#ff6b35;border-color:rgba(255,107,53,.25);background:rgba(255,107,53,.07);}
.nf-views-row.trending-views{color:var(--accent);border-color:rgba(255,26,26,.25);background:rgba(255,26,26,.07);}

.feed-ad{margin:2px 0;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);display:flex;align-items:center;gap:12px;padding:12px 14px;text-decoration:none;position:relative;transition:border-color .16s;}
.feed-ad:hover{border-color:#2a0808;}
.feed-ad::after{content:'Sponsored';position:absolute;top:5px;right:8px;font-size:9px;color:var(--text-3);letter-spacing:.08em;}
.feed-ad-img{width:48px;height:48px;border-radius:8px;background:linear-gradient(135deg,#1a0000,#0d0000);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:20px;}
.feed-ad-body .feed-ad-title{font-size:13px;font-weight:600;color:var(--text);}
.feed-ad-body .feed-ad-sub{font-size:11px;color:var(--text-2);margin-top:2px;}
.feed-ad-btn{margin-left:auto;flex-shrink:0;background:var(--grad);color:#fff;font-size:11px;font-weight:600;padding:6px 12px;border-radius:6px;white-space:nowrap;}
.skeleton{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}
.skel-img{width:100%;aspect-ratio:16/9;background:linear-gradient(90deg,var(--surface-2) 0%,var(--surface-3) 50%,var(--surface-2) 100%);background-size:200% 100%;animation:shimmer 1.1s infinite;}
.skel-body{padding:8px;display:flex;flex-direction:column;gap:5px;}
.skel-line{height:7px;border-radius:3px;background:linear-gradient(90deg,var(--surface-2) 0%,var(--surface-3) 50%,var(--surface-2) 100%);background-size:200% 100%;animation:shimmer 1.1s infinite;}
.skel-line.w70{width:70%;}
.state-msg{text-align:center;padding:40px 20px;}
.state-msg .icon{font-size:28px;display:block;margin-bottom:8px;opacity:.4;}
.state-msg p{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.1em;}
#scroll-end,#v-scroll-end,#d-scroll-end{text-align:center;padding:16px;font-size:10px;color:var(--text-3);letter-spacing:.12em;text-transform:uppercase;}
#load-sentinel,#v-load-sentinel,#d-load-sentinel{height:1px;}
.spinner{display:flex;justify-content:center;padding:14px;}
.spinner::after{content:'';width:20px;height:20px;border-radius:50%;border:2px solid var(--border);border-top-color:var(--accent);animation:spin .6s linear infinite;}

/* ══ PROMO FEED CARD ══ */
.promo-feed-card{margin:2px 0;background:linear-gradient(135deg,rgba(168,85,247,.08),rgba(236,72,153,.04));border:1px solid rgba(168,85,247,.25);border-radius:var(--radius);padding:14px;text-decoration:none;position:relative;transition:border-color .18s,transform .16s;display:flex;align-items:center;gap:12px;cursor:pointer;overflow:hidden;}
.promo-feed-card:hover{border-color:rgba(168,85,247,.5);transform:translateY(-2px);}
.promo-feed-card::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(168,85,247,.04),transparent);background-size:200% 100%;animation:shimmer 3s infinite;}
.promo-label{position:absolute;top:5px;right:8px;background:rgba(168,85,247,.2);border:1px solid rgba(168,85,247,.3);color:#c084fc;font-size:9px;font-family:var(--font-brand);letter-spacing:.5px;padding:1px 7px;border-radius:3px;}
.promo-icon{width:52px;height:52px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:22px;background:linear-gradient(135deg,rgba(168,85,247,.2),rgba(236,72,153,.15));border:1px solid rgba(168,85,247,.2);}
.promo-body{flex:1;min-width:0;}
.promo-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:3px;}
.promo-sub{font-size:11px;color:var(--text-2);line-height:1.4;}
.promo-cta{flex-shrink:0;background:var(--promo-grad);color:#fff;font-family:var(--font-brand);font-size:11px;letter-spacing:.4px;padding:7px 14px;border-radius:6px;white-space:nowrap;}

/* ══ DISK CARD ══ */
.disk-card{background:var(--surface);border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);cursor:pointer;display:flex;flex-direction:column;animation:fadeUp .26s ease both;transition:border-color .16s,transform .16s,box-shadow .16s;position:relative;}
.disk-card:hover{border-color:rgba(59,130,246,.35);transform:translateY(-3px);box-shadow:0 12px 32px rgba(59,130,246,.12);}
.disk-card:active{transform:scale(.97);}
.disk-img-wrap{position:relative;width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,rgba(59,130,246,.08),rgba(99,102,241,.06));overflow:hidden;border-radius:var(--radius) var(--radius) 0 0;display:flex;align-items:center;justify-content:center;}
.disk-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;opacity:0;transition:opacity .22s;}
.disk-img-wrap img.visible{opacity:1;}
.disk-img-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--disk-accent);opacity:.6;}
.disk-img-placeholder svg{width:28px;height:28px;stroke:currentColor;fill:none;stroke-width:1.5;}
.disk-img-placeholder span{font-size:9px;font-family:var(--font-brand);letter-spacing:.5px;}
.disk-type-badge{position:absolute;top:7px;left:7px;font-family:var(--font-brand);font-size:9px;padding:2px 7px;border-radius:4px;z-index:2;background:rgba(59,130,246,.85);color:#fff;}
.disk-size-badge{position:absolute;bottom:7px;right:7px;background:rgba(0,0,0,.8);color:#fff;font-family:var(--font-brand);font-size:10px;padding:2px 7px;border-radius:4px;backdrop-filter:blur(4px);}
.disk-hover-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.65) 0%,transparent 55%);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .16s;}
.disk-card:hover .disk-hover-overlay{opacity:1;}
.disk-dl-btn{width:40px;height:40px;border-radius:50%;background:rgba(59,130,246,.9);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(59,130,246,.4);}
.disk-dl-btn svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2;}
.disk-card-info{padding:9px 10px 11px;flex:1;display:flex;flex-direction:column;gap:4px;}
.disk-card-title{font-size:12px;font-weight:500;line-height:1.45;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.disk-card-caption{font-size:11px;color:var(--text-3);line-height:1.4;margin-top:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.disk-card-meta{font-size:10px;color:var(--text-3);margin-top:auto;display:flex;align-items:center;gap:6px;}
.disk-link-pill{font-family:var(--font-brand);font-size:9px;padding:1px 6px;border-radius:3px;background:rgba(59,130,246,.12);color:var(--disk-accent);}
.disk-topbar-title{font-family:var(--font-brand);font-size:20px;letter-spacing:1.5px;color:#fff;}
.disk-topbar-title .ext{color:var(--disk-accent);}

/* ═══════════════════════════════════════════
   PREMIUM GATE MODAL
   ═══════════════════════════════════════════ */
#premium-gate-modal{
  position:fixed;inset:0;z-index:700;
  background:rgba(0,0,0,.88);
  display:none;align-items:center;justify-content:center;padding:20px;
  backdrop-filter:blur(10px);
}
#premium-gate-modal.open{display:flex;}
.pgate-box{
  background:var(--surface);
  border:1px solid rgba(245,158,11,.3);
  border-radius:20px;
  padding:clamp(28px,4vw,44px) clamp(22px,3vw,36px);
  width:100%;max-width:440px;
  text-align:center;
  animation:sheetUp .25s ease;
  position:relative;overflow:hidden;
}
.pgate-box::before{
  content:'';position:absolute;top:-1px;left:15%;right:15%;height:2px;
  background:var(--premium-grad);border-radius:0 0 4px 4px;
}
.pgate-close{
  position:absolute;top:14px;right:14px;width:30px;height:30px;
  border-radius:50%;background:rgba(255,255,255,.06);border:1px solid var(--border-2);
  cursor:pointer;color:var(--text-2);font-size:16px;display:flex;align-items:center;justify-content:center;
}
.pgate-close:hover{background:rgba(255,26,26,.3);color:#fff;}
.pgate-icon{font-size:52px;display:block;margin-bottom:14px;animation:float 3s ease infinite;}
.pgate-title{font-family:var(--font-brand);font-size:clamp(24px,4vw,34px);letter-spacing:1.5px;color:#fff;margin-bottom:8px;}
.pgate-title span{background:var(--premium-grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.pgate-sub{font-size:13px;color:var(--text-2);line-height:1.6;margin-bottom:24px;}
.pgate-sub strong{color:var(--text);}
.pgate-cta{
  display:block;width:100%;
  background:var(--premium-grad);border:none;color:#fff;
  font-family:var(--font-brand);font-size:16px;letter-spacing:.8px;
  padding:14px 24px;border-radius:10px;cursor:pointer;
  box-shadow:0 4px 20px rgba(245,158,11,.35);
  transition:transform .14s,box-shadow .14s;
  animation:premiumGlow 3s ease infinite;
  margin-bottom:10px;
}
.pgate-cta:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(245,158,11,.55);}
.pgate-or{font-size:11px;color:var(--text-3);margin-bottom:10px;}
.pgate-login{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--surface-2);border:1px solid var(--border-2);
  color:var(--text-2);font-family:var(--font-brand);font-size:13px;letter-spacing:.4px;
  padding:10px 20px;border-radius:8px;cursor:pointer;transition:all .14s;
}
.pgate-login:hover{border-color:#2a0808;color:var(--text);}
.pgate-login svg{width:16px;height:16px;fill:#229ED9;}

/* ═══════════════════════════════
   TG AUTH MODAL
   ═══════════════════════════════ */
#tg-auth-modal {
  position: fixed; inset: 0; z-index: 800;
  background: rgba(0,0,0,.88);
  display: none; align-items: center; justify-content: center;
  padding: 20px; backdrop-filter: blur(10px);
}
#tg-auth-modal.open { display: flex; }

.tgauth-box {
  background: var(--surface); border: 1px solid var(--border-2);
  border-radius: 20px; width: 100%; max-width: 360px;
  overflow: hidden; animation: sheetUp .25s ease;
}
.tgauth-topbar {
  padding: 14px 16px; display: flex; align-items: center;
  justify-content: space-between; border-bottom: 1px solid var(--border);
}
.tgauth-topbar-label {
  font-family: var(--font-brand); font-size: 11px;
  letter-spacing: 1.2px; color: var(--text-3); text-transform: uppercase;
}
.tgauth-close {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--surface-3); border: 1px solid var(--border-2);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--text-2); font-size: 14px;
  line-height: 1; transition: all .14s;
}
.tgauth-close:hover { background: rgba(255,26,26,.2); color: var(--accent); border-color: rgba(255,26,26,.3); }

.tgauth-login-header { padding: 24px 22px 16px; text-align: center; }
.tgauth-tg-ring {
  width: 68px; height: 68px; border-radius: 50%; margin: 0 auto 14px;
  background: rgba(34,158,217,.1); border: 2px solid rgba(34,158,217,.28);
  display: flex; align-items: center; justify-content: center;
}
.tgauth-title { font-family: var(--font-brand); font-size: 20px; letter-spacing: .8px; color: #fff; margin-bottom: 6px; }
.tgauth-sub   { font-size: 12px; color: var(--text-2); line-height: 1.6; }

.tgauth-steps { padding: 0 16px 14px; display: flex; flex-direction: column; gap: 7px; }
.tgauth-step  { display: flex; align-items: flex-start; gap: 11px; padding: 10px 12px; background: var(--surface-2); border: 1px solid var(--border); border-radius: 10px; }
.tgauth-step-num {
  width: 22px; height: 22px; border-radius: 50%; flex-shrink: 0;
  background: rgba(34,158,217,.12); border: 1px solid rgba(34,158,217,.28);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-brand); font-size: 13px; color: #229ED9; margin-top: 1px;
}
.tgauth-step-title { font-size: 12px; font-weight: 500; color: var(--text); margin-bottom: 2px; }
.tgauth-step-sub   { font-size: 11px; color: var(--text-2); line-height: 1.45; }
.tgauth-step-sub code {
  background: var(--surface-3); border: 1px solid var(--border-2);
  border-radius: 4px; padding: 1px 5px; font-size: 11px;
  color: #6dd4f5; font-family: monospace;
}

.tgauth-open-btn {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  margin: 0 16px 12px; padding: 13px; border-radius: 11px;
  background: #229ED9; border: none; color: #fff; text-decoration: none;
  font-family: var(--font-brand); font-size: 15px; letter-spacing: .5px;
  cursor: pointer; transition: opacity .14s, transform .14s;
}
.tgauth-open-btn:hover { opacity: .88; transform: translateY(-1px); }

.tgauth-poll-bar {
  margin: 0 16px 12px; padding: 10px 14px;
  background: rgba(34,158,217,.07); border: 1px solid rgba(34,158,217,.2);
  border-radius: 10px; display: flex; align-items: center; gap: 10px;
  font-size: 12px; color: #229ED9;
}
.tgauth-poll-spinner {
  width: 14px; height: 14px; border-radius: 50%; flex-shrink: 0;
  border: 2px solid rgba(34,158,217,.2); border-top-color: #229ED9;
  animation: spin .7s linear infinite;
}

.tgauth-token-area {
  margin: 0 16px 16px; background: var(--surface-2);
  border: 1px solid var(--border-2); border-radius: 12px; overflow: hidden;
}
.tgauth-token-label { padding: 9px 13px 5px; font-size: 10px; color: var(--text-3); letter-spacing: .07em; text-transform: uppercase; }
.tgauth-token-row   { display: flex; border-top: 1px solid var(--border); }
.tgauth-token-input {
  flex: 1; background: transparent; border: none; color: var(--text);
  font-size: 12px; padding: 10px 13px; outline: none;
  font-family: var(--font-body);
}
.tgauth-token-input::placeholder { color: var(--text-3); }
.tgauth-token-verify {
  background: rgba(34,158,217,.12); border: none; border-left: 1px solid var(--border-2);
  color: #229ED9; font-family: var(--font-brand); font-size: 12px; letter-spacing: .4px;
  padding: 10px 15px; cursor: pointer; white-space: nowrap; transition: background .14s;
}
.tgauth-token-verify:hover { background: rgba(34,158,217,.25); }
.tgauth-token-err { padding: 5px 13px 9px; font-size: 11px; color: var(--accent); min-height: 24px; }

.tgauth-note { padding: 0 16px 16px; font-size: 10px; color: var(--text-3); text-align: center; line-height: 1.5; }

.tgauth-profile-hero {
  padding: 26px 22px 20px; text-align: center;
  background: linear-gradient(135deg, rgba(245,158,11,.07), rgba(239,68,68,.04));
  border-bottom: 1px solid var(--border);
}
.tgauth-profile-avatar {
  width: 66px; height: 66px; border-radius: 50%; margin: 0 auto 12px;
  background: var(--premium-grad);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-brand); font-size: 28px; color: #fff;
  border: 2px solid rgba(245,158,11,.35);
}
.tgauth-profile-name { font-family: var(--font-brand); font-size: 20px; letter-spacing: .6px; color: #fff; margin-bottom: 6px; }
.tgauth-profile-badge-row { display: flex; justify-content: center; gap: 6px; margin-bottom: 6px; }
.tgauth-badge-prem {
  background: rgba(245,158,11,.15); border: 1px solid rgba(245,158,11,.3);
  border-radius: 5px; font-family: var(--font-brand); font-size: 10px;
  letter-spacing: .6px; color: var(--premium-accent); padding: 2px 10px;
}
.tgauth-badge-free {
  background: rgba(255,255,255,.06); border: 1px solid var(--border-2);
  border-radius: 5px; font-family: var(--font-brand); font-size: 10px;
  letter-spacing: .6px; color: var(--text-3); padding: 2px 10px;
}

.tgauth-expiry-block {
  margin: 14px 16px 0; padding: 12px 14px;
  background: rgba(245,158,11,.07); border: 1px solid rgba(245,158,11,.18);
  border-radius: 10px; display: flex; align-items: center; gap: 12px;
}
.tgauth-expiry-icon  { font-size: 20px; flex-shrink: 0; }
.tgauth-expiry-title { font-family: var(--font-brand); font-size: 10px; letter-spacing: .7px; color: var(--premium-accent); margin-bottom: 2px; }
.tgauth-expiry-val   { font-size: 12px; color: var(--text-2); }

.tgauth-profile-actions { padding: 14px 16px 14px; display: flex; flex-direction: column; gap: 8px; }
.tgauth-upgrade-btn {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  background: var(--premium-grad); border: none; color: #fff;
  font-family: var(--font-brand); font-size: 14px; letter-spacing: .5px;
  padding: 13px; border-radius: 10px; cursor: pointer;
  transition: opacity .14s, transform .14s;
}
.tgauth-upgrade-btn:hover { opacity: .88; transform: translateY(-1px); }
.tgauth-logout-btn {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  background: rgba(255,26,26,.08); border: 1px solid rgba(255,26,26,.2);
  color: #ff6b6b; font-family: var(--font-brand); font-size: 13px; letter-spacing: .4px;
  padding: 11px; border-radius: 10px; cursor: pointer; transition: all .14s;
}
.tgauth-logout-btn:hover { background: rgba(255,26,26,.16); }

/* ═══════════════════════════════════════════
   PREMIUM PAGE
   ═══════════════════════════════════════════ */
#page-premium{width:100%;}
.premium-hero-v2{position:relative;overflow:hidden;padding:clamp(28px,5vw,72px) clamp(24px,5vw,64px) clamp(24px,4vw,56px);background:linear-gradient(135deg,rgba(245,158,11,.08) 0%,rgba(239,68,68,.06) 50%,transparent 100%);border-bottom:1px solid rgba(245,158,11,.15);}
.premium-hero-v2::before{content:'';position:absolute;top:-100px;right:-80px;width:600px;height:600px;background:radial-gradient(circle,rgba(245,158,11,.12) 0%,transparent 65%);pointer-events:none;}
.premium-hero-v2::after{content:'';position:absolute;bottom:-60px;left:-60px;width:400px;height:400px;background:radial-gradient(circle,rgba(255,26,26,.08) 0%,transparent 65%);pointer-events:none;}
.prem-hero-inner{position:relative;z-index:1;max-width:100%;}
@media(min-width:900px){.prem-hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;}.prem-hero-inner .prem-badge{grid-column:1/-1;}.prem-hero-title{font-size:clamp(48px,5vw,80px);}}
.prem-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.3);color:var(--premium-accent);font-family:var(--font-brand);font-size:11px;letter-spacing:1px;padding:4px 12px;border-radius:20px;margin-bottom:16px;}
.prem-badge-dot{width:5px;height:5px;border-radius:50%;background:var(--premium-accent);animation:pulse 1.5s infinite;}
.prem-hero-title{font-family:var(--font-brand);font-size:clamp(32px,6vw,56px);letter-spacing:2px;line-height:.95;color:#fff;margin-bottom:14px;}
.prem-hero-title .glow{background:var(--premium-grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.prem-hero-desc{font-size:clamp(12px,1.4vw,15px);color:var(--text-2);line-height:1.7;margin-bottom:28px;}
.prem-hero-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;}
.prem-demo-btn{display:inline-flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid rgba(245,158,11,.4);color:var(--premium-accent);font-family:var(--font-brand);font-size:14px;letter-spacing:.5px;padding:12px 22px;border-radius:10px;cursor:pointer;text-decoration:none;transition:all .16s;}
.prem-demo-btn:hover{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.7);transform:translateY(-1px);}
.prem-demo-btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;}
.prem-buy-btn{display:inline-flex;align-items:center;gap:8px;background:var(--premium-grad);border:none;color:#fff;font-family:var(--font-brand);font-size:14px;letter-spacing:.5px;padding:12px 26px;border-radius:10px;cursor:pointer;box-shadow:0 4px 20px rgba(245,158,11,.35);transition:transform .14s,box-shadow .14s;animation:premiumGlow 3s ease infinite;}
.prem-buy-btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(245,158,11,.55);}
.prem-buy-btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;}
.prem-plans-wrap{padding:clamp(16px,3vw,36px) clamp(16px,4vw,40px);}
.prem-plans-head{font-family:var(--font-brand);font-size:13px;letter-spacing:1.5px;color:var(--text-3);text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center;gap:8px;}
.prem-plans-head::after{content:'';flex:1;height:1px;background:var(--border);}
.prem-plans-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
@media(min-width:600px){.prem-plans-grid{grid-template-columns:repeat(3,1fr);gap:12px;}}
@media(min-width:900px){.prem-plans-grid{grid-template-columns:repeat(5,1fr);gap:14px;}}
.plan-card{background:var(--surface);border:1px solid var(--border-2);border-radius:14px;padding:20px 14px;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;cursor:pointer;transition:all .18s;position:relative;overflow:hidden;}
.plan-card:hover{border-color:rgba(245,158,11,.4);transform:translateY(-4px);box-shadow:0 12px 32px rgba(245,158,11,.15);}
.plan-card.popular{border-color:rgba(245,158,11,.5);}
.plan-card.popular::before{content:'MOST POPULAR';position:absolute;top:0;left:0;right:0;background:var(--premium-grad);color:#fff;font-family:var(--font-brand);font-size:9px;letter-spacing:.5px;padding:4px;text-align:center;}
.plan-card.popular{padding-top:28px;}
.plan-icon{font-size:28px;}
.plan-name{font-family:var(--font-brand);font-size:17px;letter-spacing:.5px;color:var(--text);}
.plan-price{font-family:var(--font-brand);font-size:30px;color:var(--premium-accent);line-height:1;}
.plan-price span{font-size:12px;color:var(--text-3);}
.plan-duration{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;}
.plan-select-btn{width:100%;margin-top:4px;background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.25);color:var(--premium-accent);font-family:var(--font-brand);font-size:11px;letter-spacing:.4px;padding:9px;border-radius:7px;cursor:pointer;transition:all .14s;}
.plan-card:hover .plan-select-btn,.plan-card.selected .plan-select-btn{background:var(--premium-grad);border-color:transparent;color:#fff;}
.prem-features-v2{padding:0 clamp(16px,4vw,40px) clamp(20px,3vw,40px);display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media(min-width:600px){.prem-features-v2{grid-template-columns:repeat(3,1fr);}}
@media(min-width:900px){.prem-features-v2{grid-template-columns:repeat(6,1fr);gap:14px;}}
.prem-feat-v2{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px 16px;display:flex;flex-direction:column;gap:8px;transition:border-color .18s,transform .16s;}
.prem-feat-v2:hover{border-color:rgba(245,158,11,.25);transform:translateY(-3px);}
.prem-feat-icon-v2{font-size:26px;}
.prem-feat-title-v2{font-family:var(--font-brand);font-size:13px;letter-spacing:.5px;color:var(--premium-accent);}
.prem-feat-desc-v2{font-size:11px;color:var(--text-2);line-height:1.5;}
.premium-content-grid{padding:0 clamp(16px,4vw,40px) clamp(20px,3vw,40px);display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
@media(min-width:600px){.premium-content-grid{grid-template-columns:repeat(3,1fr);}}
@media(min-width:900px){.premium-content-grid{grid-template-columns:repeat(4,1fr);gap:14px;}}
@media(min-width:1400px){.premium-content-grid{grid-template-columns:repeat(6,1fr);}}
.premium-lock-card{background:var(--surface);border:1px solid rgba(245,158,11,.2);border-radius:var(--radius);overflow:hidden;position:relative;cursor:pointer;transition:border-color .16s,transform .16s;}
.premium-lock-card:hover{border-color:rgba(245,158,11,.45);transform:translateY(-3px);}
.plock-img{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,rgba(245,158,11,.1),rgba(239,68,68,.06));display:flex;align-items:center;justify-content:center;font-size:32px;}
.plock-overlay{position:absolute;top:0;left:0;right:0;aspect-ratio:16/9;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;}
.plock-overlay svg{width:28px;height:28px;stroke:#f59e0b;fill:none;stroke-width:1.8;}
.plock-info{padding:9px 10px 11px;}
.plock-title{font-size:11px;color:var(--text-2);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.plock-badge{font-family:var(--font-brand);font-size:9px;color:var(--premium-accent);letter-spacing:.5px;margin-top:4px;}

/* ══ QR Modal ══ */
#qr-modal{position:fixed;inset:0;z-index:700;background:rgba(0,0,0,.88);display:none;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(8px);}
#qr-modal.open{display:flex;}
.qr-box{background:var(--surface);border:1px solid rgba(245,158,11,.3);border-radius:20px;padding:clamp(24px,3vw,36px) clamp(20px,3vw,32px);width:100%;max-width:420px;animation:sheetUp .25s ease;position:relative;text-align:center;}
.qr-box::before{content:'';position:absolute;top:-1px;left:15%;right:15%;height:2px;background:var(--premium-grad);border-radius:0 0 4px 4px;}
.qr-close{position:absolute;top:14px;right:14px;width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid var(--border-2);cursor:pointer;color:var(--text-2);font-size:16px;display:flex;align-items:center;justify-content:center;}
.qr-close:hover{background:rgba(255,26,26,.3);color:#fff;}
.qr-title{font-family:var(--font-brand);font-size:22px;letter-spacing:1px;color:#fff;margin-bottom:4px;}
.qr-subtitle{font-size:12px;color:var(--text-2);margin-bottom:20px;}
.qr-plan-tag{display:inline-block;background:var(--premium-grad);color:#fff;font-family:var(--font-brand);font-size:11px;letter-spacing:.5px;padding:4px 14px;border-radius:20px;margin-bottom:20px;}
.qr-img-wrap{width:200px;height:200px;margin:0 auto 16px;background:white;border-radius:12px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.qr-img-wrap canvas{border-radius:8px;}
.qr-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:white;border-radius:12px;}
.qr-loading::after{content:'';width:28px;height:28px;border:3px solid #eee;border-top-color:#f59e0b;border-radius:50%;animation:qrSpin .7s linear infinite;}
.qr-amount{font-family:var(--font-brand);font-size:32px;color:var(--premium-accent);margin-bottom:4px;}
.qr-order{font-size:10px;color:var(--text-3);font-family:monospace;word-break:break-all;margin-bottom:16px;}
.qr-instructions{background:rgba(245,158,11,.06);border:1px solid rgba(245,158,11,.15);border-radius:8px;padding:12px;font-size:11px;color:var(--text-2);line-height:1.6;margin-bottom:16px;}
.qr-timer{display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-brand);font-size:13px;color:var(--text-3);margin-bottom:16px;}
.qr-timer-bar{flex:1;max-width:160px;height:3px;background:var(--border);border-radius:2px;overflow:hidden;}
.qr-timer-fill{height:100%;background:var(--premium-grad);border-radius:2px;transition:width 1s linear;}
.qr-verify-btn{width:100%;background:var(--surface-2);border:1px solid var(--border-2);color:var(--text-2);font-family:var(--font-brand);font-size:13px;letter-spacing:.4px;padding:11px;border-radius:8px;cursor:pointer;transition:all .14s;}
.qr-verify-btn:hover{border-color:rgba(245,158,11,.4);color:var(--premium-accent);}

/* ══ ALBUM PLAYER ══ */
.album-list{display:flex;flex-direction:column;gap:6px;margin-bottom:18px;}
.album-item{display:flex;align-items:center;gap:10px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;cursor:pointer;transition:border-color .14s,background .14s;}
.album-item:hover{border-color:#2a0808;background:var(--surface-3);}
.album-item.playing{border-color:rgba(255,26,26,.4);background:rgba(255,26,26,.06);}
.album-item-num{font-family:var(--font-brand);font-size:18px;color:var(--text-3);width:22px;flex-shrink:0;text-align:center;}
.album-item.playing .album-item-num{color:var(--accent);}
.album-item-title{font-size:13px;font-weight:500;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.album-item-dur{font-family:var(--font-brand);font-size:10px;color:var(--text-3);flex-shrink:0;}
.album-play-icon{width:28px;height:28px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:0;transition:opacity .14s;}
.album-play-icon svg{width:10px;height:10px;fill:#fff;margin-left:2px;}
.album-item:hover .album-play-icon{opacity:1;}
.album-item.playing .album-play-icon{opacity:1;animation:pulse 1.5s infinite;}

/* ══ NOTIFICATION TOAST ══ */
#notif-toast{position:fixed;top:16px;right:16px;z-index:8000;display:flex;flex-direction:column;gap:8px;pointer-events:none;}
.notif-item{background:var(--surface);border:1px solid var(--border-2);border-radius:10px;padding:12px 14px;min-width:260px;max-width:320px;display:flex;align-items:flex-start;gap:10px;box-shadow:0 8px 32px rgba(0,0,0,.6);animation:notifSlide .3s ease;pointer-events:all;}
.notif-item.out{animation:notifOut .3s ease forwards;}
.notif-icon{font-size:20px;flex-shrink:0;margin-top:1px;}
.notif-body{flex:1;min-width:0;}
.notif-title{font-size:12px;font-weight:600;color:var(--text);margin-bottom:2px;}
.notif-sub{font-size:11px;color:var(--text-2);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.notif-close{width:18px;height:18px;flex-shrink:0;background:none;border:none;cursor:pointer;color:var(--text-3);font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center;border-radius:3px;margin-top:1px;}
.notif-close:hover{color:var(--text);}
@media(max-width:500px){#notif-toast{top:auto;bottom:calc(var(--nav-h) + 14px);right:10px;left:10px;}.notif-item{min-width:unset;max-width:unset;width:100%;}}

#notif-banner{background:linear-gradient(135deg,rgba(59,130,246,.12),rgba(99,102,241,.06));border:1px solid rgba(59,130,246,.22);border-radius:var(--radius);margin:8px 10px;padding:12px 14px;display:none;align-items:center;gap:10px;}
#notif-banner.show{display:flex;}
.notif-banner-icon{font-size:20px;flex-shrink:0;}
.notif-banner-body{flex:1;}
.notif-banner-title{font-size:12px;font-weight:600;color:var(--text);}
.notif-banner-sub{font-size:11px;color:var(--text-2);margin-top:2px;}
.notif-banner-btns{display:flex;gap:7px;flex-shrink:0;}
.notif-allow-btn{background:var(--disk-grad);color:#fff;font-family:var(--font-brand);font-size:11px;letter-spacing:.4px;padding:6px 14px;border-radius:6px;border:none;cursor:pointer;}
.notif-dismiss-btn{background:var(--surface-2);border:1px solid var(--border-2);color:var(--text-2);font-family:var(--font-brand);font-size:11px;padding:6px 10px;border-radius:6px;cursor:pointer;}

/* ═══════════════════════════════════════════
   CALENDAR
   ═══════════════════════════════════════════ */
#page-calendar{width:100%;}
.cal-header{padding:24px 24px 0;}
@media(min-width:900px){.cal-header{padding:32px 40px 0;}}
.cal-header h2{font-family:var(--font-brand);font-size:clamp(22px,3vw,34px);letter-spacing:1.5px;color:#fff;}
.cal-header p{font-size:11px;color:var(--text-3);margin-top:2px;}
.year-tabs{display:flex;gap:6px;padding:16px 24px 0;flex-wrap:wrap;}
@media(min-width:900px){.year-tabs{padding:20px 40px 0;}}
.year-tab{padding:5px 18px;border-radius:5px;font-family:var(--font-brand);font-size:13px;cursor:pointer;border:none;transition:all .14s;}
.year-tab.active{background:var(--accent);color:#fff;}
.year-tab:not(.active){background:var(--surface-2);color:var(--text-2);border:1px solid var(--border-2);}
#cal-body{padding:12px 16px 28px;}
@media(min-width:900px){#cal-body{padding:16px 40px 40px;}}
.month-block{margin-top:20px;}
.month-name{font-family:var(--font-brand);font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--text-3);margin-bottom:10px;}
.day-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;}
@media(min-width:600px){.day-grid{grid-template-columns:repeat(7,1fr);gap:8px;}}
@media(min-width:900px){.day-grid{grid-template-columns:repeat(10,1fr);gap:10px;}}
@media(min-width:1200px){.day-grid{grid-template-columns:repeat(14,1fr);gap:10px;}}
@media(min-width:1600px){.day-grid{grid-template-columns:repeat(18,1fr);}}
@media(min-width:900px){#cal-body{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;align-items:start;}}
@media(min-width:1400px){#cal-body{grid-template-columns:repeat(3,1fr);}}
.day-btn{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:9px 4px 7px;text-align:center;cursor:pointer;transition:border-color .14s,background .14s;display:flex;flex-direction:column;align-items:center;gap:3px;}
.day-btn:hover{border-color:#2a0808;background:var(--surface-2);}
.day-btn .dn{font-family:var(--font-brand);font-size:18px;line-height:1;}
.day-btn .dw{font-size:8px;font-weight:500;letter-spacing:.08em;color:var(--text-3);text-transform:uppercase;}
.day-btn .cnt{background:var(--accent);color:#fff;font-size:9px;font-weight:700;padding:1px 6px;border-radius:3px;min-width:22px;}

/* ══ DAY MODAL ══ */
#day-modal{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.82);display:none;align-items:flex-end;justify-content:center;}
#day-modal.open{display:flex;}
.modal-sheet{background:var(--surface);border-radius:14px 14px 0 0;width:100%;max-width:700px;max-height:80vh;overflow-y:auto;padding:14px 10px 28px;animation:sheetUp .22s ease;}
.modal-drag{width:28px;height:3px;border-radius:2px;background:var(--border-2);margin:0 auto 12px;}
.modal-title{font-family:var(--font-brand);font-size:15px;letter-spacing:.5px;margin-bottom:12px;color:var(--accent);}
.modal-feed{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;}
@media(min-width:600px){.modal-feed{grid-template-columns:repeat(3,1fr);}}

/* ══ REQUEST VIDEO MODAL ══ */
#req-modal{position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.85);display:none;align-items:center;justify-content:center;padding:20px;}
#req-modal.open{display:flex;}
.req-box{background:var(--surface);border:1px solid var(--border-2);border-radius:16px;padding:26px 22px;width:100%;max-width:440px;animation:sheetUp .22s ease;position:relative;}
.req-box h3{font-family:var(--font-brand);font-size:22px;letter-spacing:.8px;margin-bottom:4px;color:#fff;}
.req-box p{font-size:12px;color:var(--text-3);margin-bottom:18px;line-height:1.5;}
.req-close{position:absolute;top:14px;right:14px;width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid var(--border-2);cursor:pointer;color:var(--text-2);font-size:16px;display:flex;align-items:center;justify-content:center;}
.req-close:hover{background:rgba(255,26,26,.3);color:#fff;}
.req-box label{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:5px;}
.req-box textarea{width:100%;background:var(--surface-2);border:1px solid var(--border-2);border-radius:8px;color:var(--text);font-family:var(--font-body);font-size:13px;padding:11px 13px;outline:none;resize:vertical;min-height:90px;transition:border-color .18s;margin-bottom:14px;}
.req-box textarea:focus{border-color:#2a0808;}
.req-box textarea::placeholder{color:var(--text-3);}
.req-btns{display:flex;gap:10px;justify-content:flex-end;}
.req-cancel{background:var(--surface-2);border:1px solid var(--border-2);color:var(--text-2);font-family:var(--font-brand);font-size:13px;letter-spacing:.4px;padding:9px 18px;border-radius:8px;cursor:pointer;transition:background .14s;}
.req-cancel:hover{background:var(--surface-3);}
.req-send{background:var(--grad);border:none;color:#fff;font-family:var(--font-brand);font-size:14px;letter-spacing:.5px;padding:10px 22px;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:opacity .14s;}
.req-send:hover{opacity:.85;}
.req-send svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;}
.req-fab{position:fixed;bottom:calc(var(--nav-h) + 14px);right:14px;background:var(--grad);border:none;border-radius:50px;color:#fff;font-family:var(--font-brand);font-size:12px;letter-spacing:.5px;padding:10px 16px;cursor:pointer;box-shadow:0 4px 20px rgba(255,26,26,.35);z-index:100;display:flex;align-items:center;gap:6px;transition:transform .14s,box-shadow .14s;}
.req-fab:hover{transform:translateY(-2px);box-shadow:0 6px 26px rgba(255,26,26,.5);}
.req-fab svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.2;}
@media(min-width:900px){.req-fab{bottom:20px;}}

.made-by{text-align:center;padding:18px 16px 24px;font-size:11px;color:var(--text-3);letter-spacing:.06em;border-top:1px solid var(--border);margin-top:8px;}
.made-by a{color:var(--accent);text-decoration:none;font-family:var(--font-brand);font-size:12px;letter-spacing:.5px;}

/* ═══════════════════════════════════════════
   NETFLIX VIDEO PLAYER — ENHANCED
   ═══════════════════════════════════════════ */
#page-player{background:var(--bg);min-height:100vh;width:100%;}
.player-back{position:absolute;top:env(safe-area-inset-top,16px);left:16px;z-index:50;display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:50px;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.85);font-size:13px;font-weight:500;font-family:var(--font-body);cursor:pointer;transition:background .18s,color .18s;text-decoration:none;}
.player-back:hover{background:rgba(255,26,26,.7);color:#fff;border-color:transparent;}
.player-back svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2.2;flex-shrink:0;}
.nf-hero{position:relative;width:100%;background:#000;overflow:hidden;}
video::-webkit-media-controls-download-button{display:none!important;}
video::-webkit-media-controls-enclosure{overflow:hidden;}

/* ══ RESPONSIVE PLAYER STAGE (Update 2) ══ */
.nf-stage-wrap{position:relative;width:100%;background:#000;min-height:200px;}
.nf-stage-wrap video{display:block;width:100%;height:auto;min-height:200px;max-height:min(56.25vw,80vh);object-fit:contain;background:#000;border:none;outline:none;}
.nf-stage-wrap iframe{display:block;width:100%;height:min(56.25vw,80vh);min-height:200px;border:none;outline:none;background:#000;}
@media(min-width:900px){
  .nf-stage-wrap video{max-height:min(56.25vw,76vh);}
  .nf-stage-wrap iframe{height:min(56.25vw,76vh);}
}

/* ══ PLAYER CONTROLS OVERLAY ══ */
.player-controls-bar{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.4) 60%,transparent 100%);
  padding:32px 16px 12px;
  display:flex;align-items:center;gap:10px;
  opacity:0;transition:opacity .22s;
  z-index:15;pointer-events:none;
}
.nf-hero:hover .player-controls-bar{opacity:1;pointer-events:all;}
.player-progress-wrap{
  position:absolute;bottom:46px;left:16px;right:16px;
  height:3px;background:rgba(255,255,255,.18);border-radius:2px;
  cursor:pointer;z-index:16;
  opacity:0;transition:opacity .22s,height .14s;
}
.nf-hero:hover .player-progress-wrap{opacity:1;}
.player-progress-wrap:hover{height:5px;}
.player-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .1s linear;position:relative;}
.player-progress-fill::after{content:'';position:absolute;right:-5px;top:50%;transform:translateY(-50%);width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px rgba(255,26,26,.6);opacity:0;transition:opacity .14s;}
.player-progress-wrap:hover .player-progress-fill::after{opacity:1;}

/* ══ FS + PIP BUTTONS (Update 3) ══ */
.fs-btn{position:absolute;bottom:10px;right:10px;z-index:20;width:34px;height:34px;border-radius:8px;background:rgba(0,0,0,.65);border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .14s;}
.fs-btn:hover{background:rgba(255,26,26,.7);}
.fs-btn svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2;}

.pip-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:8px;background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.3);color:#3b82f6;font-size:13px;font-weight:500;cursor:pointer;transition:all .14s;}
.pip-btn:hover{background:rgba(59,130,246,.22);transform:translateY(-1px);}
.pip-btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;}

.player-domain-badge{position:absolute;bottom:54px;right:12px;background:rgba(0,0,0,.78);color:rgba(255,255,255,.55);font-size:11px;padding:4px 10px;border-radius:5px;backdrop-filter:blur(6px);opacity:0;transition:opacity .22s;pointer-events:none;z-index:20;letter-spacing:.03em;}
.nf-hero:hover .player-domain-badge{opacity:1;}

/* ══ SPEED BADGE ══ */
.player-speed-badge{
  position:absolute;top:14px;left:50%;transform:translateX(-50%);
  background:rgba(0,0,0,.78);color:var(--accent);
  font-family:var(--font-brand);font-size:14px;letter-spacing:1px;
  padding:4px 14px;border-radius:6px;
  opacity:0;pointer-events:none;z-index:25;
  transition:opacity .18s;backdrop-filter:blur(6px);
  border:1px solid rgba(255,26,26,.25);
}
.player-speed-badge.show{opacity:1;}

/* ══ SKIP OVERLAYS ══ */
.skip-overlay{
  position:absolute;top:0;bottom:0;width:30%;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .16s;pointer-events:none;z-index:18;
}
.skip-overlay-left{left:0;background:linear-gradient(to right,rgba(255,26,26,.12),transparent);}
.skip-overlay-right{right:0;background:linear-gradient(to left,rgba(255,26,26,.12),transparent);}
.skip-overlay.flash{opacity:1;}
.skip-icon{font-family:var(--font-brand);font-size:13px;color:rgba(255,255,255,.9);display:flex;flex-direction:column;align-items:center;gap:4px;}
.skip-icon svg{width:22px;height:22px;stroke:rgba(255,255,255,.9);fill:none;stroke-width:2;}

.nf-hero-fade{position:absolute;bottom:0;left:0;right:0;height:80px;background:linear-gradient(to bottom,transparent,var(--bg));pointer-events:none;z-index:2;}
.nf-info{padding:20px 16px 0;}
@media(min-width:900px){.nf-info{padding:32px 48px 0;display:grid;grid-template-columns:1fr 360px;gap:40px;align-items:start;}.nf-info>*{grid-column:1;}#player-album-section{grid-column:2;grid-row:1 / span 6;margin-top:0!important;}}
@media(min-width:1200px){.nf-info{padding:36px 64px 0;grid-template-columns:1fr 400px;gap:48px;}}
.nf-title{font-family:var(--font-brand);font-size:clamp(22px,3vw,44px);letter-spacing:.5px;color:#fff;line-height:1.1;margin-bottom:10px;}
.nf-meta{display:flex;align-items:center;flex-wrap:wrap;gap:8px 14px;margin-bottom:14px;}
.nf-meta-pill{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:rgba(255,255,255,.55);font-weight:500;}
.nf-meta-pill svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;flex-shrink:0;}
.nf-quality-pill{background:rgba(255,69,0,.18);color:#ff6b35;font-family:var(--font-brand);font-size:11px;letter-spacing:.8px;padding:3px 9px;border-radius:4px;border:1px solid rgba(255,69,0,.3);}
.nf-new-pill{background:rgba(255,26,26,.18);color:var(--accent);font-family:var(--font-brand);font-size:11px;letter-spacing:.8px;padding:3px 9px;border-radius:4px;border:1px solid rgba(255,26,26,.3);}
.nf-album-pill{background:rgba(99,102,241,.18);color:#818cf8;font-family:var(--font-brand);font-size:11px;letter-spacing:.8px;padding:3px 9px;border-radius:4px;border:1px solid rgba(99,102,241,.3);}
.nf-premium-pill{background:rgba(245,158,11,.18);color:var(--premium-accent);font-family:var(--font-brand);font-size:11px;letter-spacing:.8px;padding:3px 9px;border-radius:4px;border:1px solid rgba(245,158,11,.3);}
.nf-reactions{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap;}
.react-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:50px;font-family:var(--font-brand);font-size:13px;letter-spacing:.4px;cursor:pointer;transition:all .16s;user-select:none;background:var(--surface-2);border:1px solid var(--border-2);color:var(--text-2);}
.react-btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;transition:fill .16s;}
.react-btn:hover{border-color:#2a0808;color:var(--text);}
.react-btn.liked{background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.35);color:var(--like);}
.react-btn.liked svg{fill:var(--like);stroke:var(--like);}
.react-btn.disliked{background:rgba(248,113,113,.12);border-color:rgba(248,113,113,.35);color:var(--dislike);}
.react-btn.disliked svg{fill:var(--dislike);stroke:var(--dislike);}
.react-btn.pop{animation:likePop .32s ease;}
.react-count{font-size:13px;}
.react-divider{width:1px;height:22px;background:var(--border-2);}
.nf-actions{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap;}
.nf-btn{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;border-radius:8px;font-size:13px;font-weight:500;font-family:var(--font-body);cursor:pointer;transition:all .16s;white-space:nowrap;text-decoration:none;}
.nf-btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;flex-shrink:0;}
.nf-btn-outline{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.8);}
.nf-btn-outline:hover{background:rgba(255,255,255,.13);color:#fff;border-color:rgba(255,255,255,.28);}
.nf-btn-tg{background:var(--grad);border:none;color:#fff;}
.nf-btn-tg:hover{opacity:.88;transform:translateY(-1px);}
.nf-desc{font-size:13px;color:rgba(255,255,255,.55);line-height:1.65;margin-bottom:24px;padding:14px 16px;background:rgba(255,255,255,.03);border-left:3px solid var(--accent);border-radius:0 6px 6px 0;}
.nf-divider{border:none;border-top:1px solid var(--border);margin:0 0 20px;}
.nf-related{padding:0 16px 32px;}
@media(min-width:900px){.nf-related{padding:0 48px 40px;}}
@media(min-width:1200px){.nf-related{padding:0 64px 48px;}}
.nf-related-header{font-family:var(--font-brand);font-size:15px;letter-spacing:1.2px;color:var(--text);margin-bottom:12px;display:flex;align-items:center;gap:10px;}
.nf-related-header::after{content:'';flex:1;height:1px;background:var(--border);}
.related-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;}
@media(min-width:600px){.related-grid{grid-template-columns:repeat(3,1fr);}}
@media(min-width:900px){.related-grid{grid-template-columns:repeat(4,1fr);gap:12px;}}
@media(min-width:1200px){.related-grid{grid-template-columns:repeat(5,1fr);}}
@media(min-width:1600px){.related-grid{grid-template-columns:repeat(6,1fr);}}
.vpage-topbar{position:sticky;top:0;z-index:100;background:rgba(6,0,0,.97);border-bottom:1px solid var(--border);backdrop-filter:blur(14px);padding:11px 16px;display:flex;align-items:center;gap:12px;}
@media(min-width:900px){.vpage-topbar{padding:12px 20px;}}

/* ══ BOTTOM NAV ══ */
nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-h);background:rgba(6,0,0,.98);border-top:1px solid var(--border);backdrop-filter:blur(16px);display:flex;align-items:center;justify-content:space-around;z-index:200;}
.nav-btn{display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;border:none;background:transparent;padding:6px 10px;border-radius:8px;transition:background .14s;position:relative;}
.nav-btn.active{background:rgba(255,26,26,.08);}
.nav-btn.disk-nav.active{background:rgba(59,130,246,.08);}
.nav-btn.premium-nav.active{background:rgba(245,158,11,.08);}
.nav-btn svg{width:20px;height:20px;stroke:var(--text-3);fill:none;stroke-width:1.8;transition:stroke .14s;}
.nav-btn.active svg{stroke:var(--accent);}
.nav-btn.disk-nav.active svg{stroke:var(--disk-accent);}
.nav-btn.premium-nav.active svg{stroke:var(--premium-accent);}
.nav-btn .nav-label{font-family:var(--font-brand);font-size:9px;letter-spacing:.5px;color:var(--text-3);text-transform:uppercase;transition:color .14s;}
.nav-btn.active .nav-label{color:var(--accent);}
.nav-btn.disk-nav.active .nav-label{color:var(--disk-accent);}
.nav-btn.premium-nav.active .nav-label{color:var(--premium-accent);}
.nav-btn.premium-nav .nav-label::after{content:'✦';font-size:6px;color:var(--premium-accent);margin-left:2px;vertical-align:middle;}

/* ══ PAGES ══ */
.page{display:none;min-height:100vh;}
.page.active{display:block;animation:pageIn .2s ease;}

/* ── PLANS LOGIN GATE ── */
.plans-login-gate {
  margin: 0 0 18px;
  background: linear-gradient(135deg, rgba(245,158,11,.08), rgba(239,68,68,.05));
  border: 1px solid rgba(245,158,11,.28);
  border-radius: 14px;
  padding: 18px 16px;
  display: flex;
  align-items: center;
  gap: 14px;
  animation: fadeUp .3s ease;
}
.plg-icon {
  width: 48px; height: 48px;
  border-radius: 10px; flex-shrink: 0;
  background: rgba(245,158,11,.12);
  border: 1px solid rgba(245,158,11,.25);
  display: flex; align-items: center; justify-content: center;
  font-size: 22px;
  animation: float 3s ease infinite;
}
.plg-body { flex: 1; }
.plg-title {
  font-family: var(--font-brand);
  font-size: 16px; letter-spacing: .5px;
  color: #fff; margin-bottom: 4px;
}
.plg-sub {
  font-size: 11px; color: var(--text-2); line-height: 1.5;
}
.plg-btn {
  flex-shrink: 0;
  background: var(--premium-grad);
  border: none; color: #fff;
  font-family: var(--font-brand);
  font-size: 12px; letter-spacing: .5px;
  padding: 10px 18px; border-radius: 10px;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(245,158,11,.3);
  animation: premiumGlow 3s ease infinite;
  white-space: nowrap;
  transition: transform .14s;
  display: flex; align-items: center; gap: 8px;
}
.plg-btn:hover { transform: translateY(-2px); }
@media (max-width: 600px) {
  .plans-login-gate { flex-direction: column; text-align: center; }
  .plg-icon { margin: 0 auto; }
  .plg-btn { width: 100%; justify-content: center; }
}

/* ── LOCKED PLAN CARD ── */
.plan-card.locked {
  pointer-events: none;
  opacity: .55;
  filter: grayscale(.3);
}
.plan-card.locked::after {
  content: '';
  position: absolute; inset: 0;
  background: rgba(6,0,0,.35);
  z-index: 1;
  border-radius: 14px;
}
.plan-lock-badge {
  position: absolute;
  bottom: 8px; right: 8px; z-index: 2;
  background: rgba(245,158,11,.12);
  border: 1px solid rgba(245,158,11,.25);
  border-radius: 5px;
  padding: 2px 8px;
  font-family: var(--font-brand);
  font-size: 9px; letter-spacing: .4px;
  color: var(--premium-accent);
}

/* ── ACTIVE PLAN BANNER ── */
.apb {
  display: flex; align-items: center; gap: 14px;
  background: var(--surface-2);
  border: 1px solid var(--border-2);
  border-radius: 14px;
  padding: 14px 16px;
  margin: 0 clamp(12px,4vw,28px) 16px;
  animation: fadeUp .3s ease;
}
.apb-login { border-color: rgba(34,197,94,.2); }
.apb-free  { border-color: rgba(255,26,26,.2); }
.apb-active{ border-color: rgba(245,158,11,.3); background: linear-gradient(135deg,rgba(245,158,11,.07),rgba(239,68,68,.04)); }
.apb-urgent{ border-color: rgba(255,26,26,.45)!important; }
.apb-warn  { border-color: rgba(245,158,11,.45)!important; }
.apb-icon, .apb-crown { font-size: 26px; flex-shrink: 0; }
.apb-body, .apb-active-inner { flex: 1; min-width: 0; }
.apb-title { font-family: var(--font-brand); font-size: 14px; letter-spacing: .4px; color: #fff; }
.apb-sub   { font-size: 11px; color: var(--text-2); margin-top: 3px; }
.apb-active-header { display: flex; align-items: baseline; gap: 8px; margin-bottom: 6px; }
.apb-active-title  { font-family: var(--font-brand); font-size: 14px; letter-spacing: .6px; color: var(--premium-accent); }
.apb-active-name   { font-size: 11px; color: var(--text-2); }
.apb-remain        { font-family: var(--font-brand); font-size: 13px; color: var(--text-2); margin-bottom: 4px; }
.apb-remain.apb-urgent { color: var(--accent); }
.apb-remain.apb-warn   { color: var(--premium-accent); }
.apb-remain.apb-expired{ color: var(--accent); }
.apb-expiry-str    { font-size: 10px; color: var(--text-3); margin-bottom: 6px; }
.apb-progress-wrap { height: 3px; background: var(--border); border-radius: 2px; overflow: hidden; }
.apb-progress-bar  { height: 100%; background: var(--premium-grad); border-radius: 2px; transition: width 1s linear; }
.apb-btn {
  flex-shrink: 0; border: none; cursor: pointer;
  font-family: var(--font-brand); font-size: 12px; letter-spacing: .4px;
  padding: 9px 16px; border-radius: 9px;
  display: flex; align-items: center; gap: 7px;
  transition: all .14s; white-space: nowrap;
}
.apb-btn-tg      { background: #229ED9; color: #fff; }
.apb-btn-upgrade { background: var(--grad); color: #fff; box-shadow: 0 4px 14px rgba(255,26,26,.25); }
.apb-btn-renew   { background: rgba(245,158,11,.12); border: 1px solid rgba(245,158,11,.3); color: var(--premium-accent); }
.apb-btn:hover   { transform: translateY(-1px); opacity: .9; }
@media(max-width:500px) {
  .apb { flex-wrap: wrap; }
  .apb-btn { width: 100%; justify-content: center; }
}