/* =====================================================
   KazançTube - kazanctube.css
   Mobile-first, responsive
   ===================================================== */

/* ---------- ROOT & RESET ---------- */
:root{
  --bg:#07090F; --bg2:#0D1117; --card:#111827; --card2:#1a2235;
  --accent:#6C63FF; --accent2:#8B5CF6; --text:#F1F5F9; --muted:#8B949E;
  --border:#1E2A3A; --red:#EF4444; --green:#10B981; --yellow:#F59E0B;
  --radius-sm: 8px; --radius-md: 12px; --radius-lg: 16px; --nav-h: 60px;
}
*{margin:0;padding:0;box-sizing:border-box;font-family:'Inter',system-ui,sans-serif;text-decoration:none;-webkit-tap-highlight-color:transparent;}
body{background:var(--bg);color:var(--text);min-height:100vh;opacity:0;transition:opacity .3s;}
body.loaded{opacity:1;}

/* ---------- LAYOUT (Mobile-first) ---------- */
.layout{display:flex;flex-direction:column;min-height:calc(100vh - var(--nav-h));}
.sidebar{display:none;} /* Mobilde gizli */
.main{flex:1;padding:16px;overflow:auto;}

/* ---------- SEARCH ---------- */
.search-wrap{position:relative;margin-bottom:16px;}
.search-wrap input{width:100%;padding:12px 16px 12px 42px;background:var(--card);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-md);font-size:.88rem;outline:none;transition:.2s;}
.search-wrap input:focus{border-color:var(--accent);}
.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted);}
.search-clear{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--muted);cursor:pointer;font-size:1rem;display:none;}

/* ---------- PAGE HEADER ---------- */
.ph{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:10px;}
.ph h2{font-size:1.1rem;font-weight:800;}
.cnt{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:3px 11px;font-size:.76rem;color:var(--muted);}

/* ---------- VIDEO GRID ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:15px;}
.vcard{background:var(--card);border-radius:var(--radius-md);border:1px solid var(--border);overflow:hidden;cursor:pointer;transition:.3s;}
.vcard:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 14px 36px rgba(0,0,0,.5);}
.thumb{position:relative;aspect-ratio:16/9;overflow:hidden;background:#000;}
.thumb img{width:100%;height:100%;object-fit:cover;transition:.3s;}
.vcard:hover .thumb img{transform:scale(1.04);}
.play-ov{position:absolute;inset:0;background:rgba(0,0,0,0);display:flex;align-items:center;justify-content:center;transition:.3s;}
.vcard:hover .play-ov{background:rgba(0,0,0,.3);}
.play-ico{font-size:2.2rem;opacity:0;transition:.3s;}
.vcard:hover .play-ico{opacity:1;}
.vcard-body{padding:11px 13px;}
.vcard-title{font-weight:700;font-size:.87rem;margin-bottom:5px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.vcard-channel{display:flex;align-items:center;gap:6px;margin-bottom:5px;cursor:pointer;}
.ch-mini-av{width:22px;height:22px;border-radius:50%;object-fit:cover;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#fff;flex-shrink:0;}
.ch-mini-name{color:var(--muted);font-size:.76rem;font-weight:600;transition:.2s;}
.ch-mini-name:hover{color:var(--accent);}
.vcard-meta{display:flex;justify-content:space-between;align-items:center;}
.vmeta-left{display:flex;gap:10px;align-items:center;}
.vviews{color:var(--muted);font-size:.73rem;}
.vlikes{color:var(--yellow);font-size:.73rem;font-weight:600;}
.vearn{color:var(--green);font-weight:700;font-size:.76rem;}
.tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:6px;}
.tag{background:rgba(108,99,255,.1);color:var(--accent);padding:2px 7px;border-radius:4px;font-size:.69rem;font-weight:600;}
.vcards-actions{display:flex;gap:6px;padding:8px 12px;border-top:1px solid var(--border);}
.vbtn-report{flex:1;padding:6px;background:rgba(239,68,68,.08);color:var(--red);border:1px solid rgba(239,68,68,.25);border-radius:6px;cursor:pointer;font-size:.74rem;font-weight:600;transition:.2s;}
.vbtn-report:hover{background:var(--red);color:#fff;}
.empty{text-align:center;padding:60px;color:var(--muted);}

/* ── PLAYER MODAL ── */
.modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:9000;justify-content:center;align-items:flex-start;padding:16px 8px;overflow-y:auto;}
.modal.open{display:flex;}
.mpanel{background:var(--card2);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:880px;margin:auto;}
.mp-body{padding:16px;}
.vwrap{border-radius:var(--radius-md);overflow:hidden;background:#000;aspect-ratio:16/9;position:relative;}
.vwrap iframe{width:100%;height:100%;border:none;display:block;}
/* ═══════════════════════════════════════════════
   AD MODAL — Tam ekran, YouTube tarzı premium kart
   ═══════════════════════════════════════════════ */

/* Tam ekran arkaplan katmanı */
.ad-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9500;                           /* player-modal (9000) üstünde */
  background: rgba(4, 6, 12, 0.82);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.ad-modal.open { display: flex; }

/* Ana kart */
.ad-modal-inner {
  width: 100%;
  max-width: 820px;
  background: linear-gradient(160deg, rgba(26,34,53,.98) 0%, rgba(13,17,23,.98) 100%);
  border: 1px solid rgba(108,99,255,.28);
  border-radius: 22px;
  box-shadow:
    0 0 0 1px rgba(108,99,255,.1),
    0 24px 60px rgba(0,0,0,.7),
    0 4px 16px rgba(108,99,255,.12);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

/* ── Üst satır ── */
.ad-top-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 26px 14px;
  border-bottom: 1px solid rgba(255,255,255,.05);
}

.ad-sponsored-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .82rem;
  font-weight: 700;
  color: var(--muted);
  letter-spacing: .3px;
}
.ad-sponsored-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
  animation: adpulse 1.4s ease-in-out infinite;
}
@keyframes adpulse {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.35; transform:scale(.65); }
}

/* Geri sayım hapı */
.ad-timer-pill {
  display: flex;
  align-items: center;
  gap: 5px;
  background: rgba(108,99,255,.14);
  border: 1px solid rgba(108,99,255,.3);
  border-radius: 30px;
  padding: 6px 16px;
  font-size: 1rem;
  font-weight: 800;
  color: var(--text);
  min-width: 88px;
  justify-content: center;
  letter-spacing: .2px;
}
.ad-timer-icon { font-size: .9rem; }
#ad-t {
  color: var(--accent);
  font-variant-numeric: tabular-nums;
}

/* ── Banner alanı ── */
.ad-banner-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;            /* etrafında 24px boşluk */
  background: transparent;
}

/* Masaüstü: 728x90 */
#adsterra-banner {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 728px;
  height: 90px;
  max-width: 100%;
  overflow: hidden;
}

/* Mobilde 320x50 boyutuna düşür */
@media (max-width: 767px) {
  #adsterra-banner {
    width: 320px;
    height: 50px;
  }
  .ad-banner-wrap {
    padding: 16px 12px;
  }
}

/* ── Alt kısım ── */
.ad-bottom-bar {
  padding: 0 26px 20px;
  border-top: 1px solid rgba(255,255,255,.05);
}

/* İlerleme çubuğu */
.ad-progress-bar {
  width: 100%;
  height: 3px;
  background: rgba(255,255,255,.07);
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: 14px;
  margin-top: 16px;
}
.ad-progress-fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  border-radius: 3px;
  transition: width .12s linear;
}

/* Alt bilgi + buton satırı */
.ad-bottom-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}
.ad-earn-hint {
  font-size: .78rem;
  color: var(--muted);
  flex: 1;
  min-width: 0;
  line-height: 1.4;
}

/* Reklamı Geç butonu */
.ad-skip {
  flex-shrink: 0;
  padding: 9px 22px;
  border: none;
  border-radius: 10px;
  font-size: .82rem;
  font-weight: 700;
  cursor: pointer;
  transition: background .25s, color .25s, box-shadow .25s, opacity .2s;
  white-space: nowrap;
}
/* Pasif (ilk 5sn) */
.ad-skip.disabled {
  background: rgba(255,255,255,.07);
  color: var(--muted);
  cursor: not-allowed;
  pointer-events: none;
}
/* Aktif (mor) */
.ad-skip.active {
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent2) 100%);
  color: #fff;
  box-shadow: 0 4px 18px rgba(108,99,255,.45);
}
.ad-skip.active:hover { opacity: .88; }

/* Mobil düzenleme */
@media (max-width: 500px) {
  .ad-top-bar    { padding: 14px 16px 10px; }
  .ad-bottom-bar { padding: 0 16px 16px; }
  .ad-sponsored-label { font-size: .74rem; }
  .ad-timer-pill { padding: 5px 12px; font-size: .9rem; min-width: 76px; }
  .ad-bottom-row { gap: 10px; }
  .ad-earn-hint  { font-size: .72rem; }
  .ad-skip       { padding: 8px 16px; font-size: .78rem; }
}
.m-title{font-size:1.05rem;font-weight:800;margin:14px 0 4px;}
.m-channel-row{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap;}
.m-ch-av{width:36px;height:36px;border-radius:50%;object-fit:cover;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;cursor:pointer;flex-shrink:0;}
.m-ch-info{flex:1;cursor:pointer;}
.m-ch-name{font-weight:700;font-size:.9rem;transition:.2s;}
.m-ch-name:hover{color:var(--accent);}
.m-ch-subs{color:var(--muted);font-size:.74rem;}
.btn-sub{padding:8px 18px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-weight:700;font-size:.82rem;transition:.2s;}
.btn-sub.unsub{background:var(--accent);color:#fff;}
.btn-sub.subd{background:var(--card);color:var(--muted);border:1px solid var(--border);}
.btn-sub.subd:hover{background:rgba(239,68,68,.1);color:var(--red);border-color:var(--red);}
.m-meta{
  display:flex;
  gap: 12px;
  color:var(--muted);
  font-size:.8rem;
  margin-bottom:14px;
  flex-wrap:wrap;
  align-items:center;
}
.m-actions {
  display: flex;
  gap: 8px;
  margin-left: auto;
}
.m-meta span{display:flex;align-items:center;gap:4px;}
.btn-like{padding:7px 16px;background:rgba(245,158,11,.1);color:var(--yellow);border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-sm);cursor:pointer;font-weight:700;font-size:.82rem;transition:.2s;}
.btn-like:hover{background:var(--yellow);color:#000;}
.btn-like.liked{background:var(--yellow);color:#000;}
.btn-report-modal{padding:7px 14px;background:rgba(239,68,68,.08);color:var(--red);border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-sm);cursor:pointer;font-weight:600;font-size:.8rem;transition:.2s;}
.btn-report-modal:hover{background:var(--red);color:#fff;}
.btn-close-m{width:100%;margin-top:8px;text-align:center;padding:8px 18px;background:rgba(239,68,68,.1);color:var(--red);border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-sm);cursor:pointer;font-weight:600;font-size:.83rem;transition:.2s;}
.btn-close-m:hover{background:var(--red);color:#fff;}

/* ── COMMENTS ── */
.comments{border-top:1px solid var(--border);padding-top:16px;margin-top:4px;}
.comments h4{font-size:.9rem;margin-bottom:14px;}
.c-input-row{display:flex;gap:10px;margin-bottom:16px;align-items:flex-start;}
.c-av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;flex-shrink:0;}
.c-box{flex:1;}
.c-ta{width:100%;padding:9px 13px;background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);resize:none;font-family:inherit;font-size:.84rem;outline:none;min-height:64px;transition:.2s;}
.c-ta:focus{border-color:var(--accent);}
.c-acts{display:flex;justify-content:flex-end;gap:7px;margin-top:7px;}
.btn-sm{padding:7px 14px;border:none;border-radius:7px;cursor:pointer;font-weight:600;font-size:.78rem;transition:.2s;}
.btn-accent{background:var(--accent);color:#fff;}
.btn-ghost{background:var(--card);color:var(--muted);}
.ci{padding:11px 0;border-bottom:1px solid var(--border);}
.ci:last-child{border-bottom:none;}
.ci-head{display:flex;align-items:center;gap:8px;margin-bottom:5px;}
.ci-av{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.72rem;flex-shrink:0;}
.ci-name{font-weight:600;font-size:.82rem;}
.ci-time{color:var(--muted);font-size:.7rem;}
.ci-txt{font-size:.84rem;line-height:1.5;padding-left:36px;}
.ci-tag{background:rgba(108,99,255,.1);color:var(--accent);padding:1px 5px;border-radius:3px;font-size:.76rem;}
.ci-btns{padding-left:36px;margin-top:5px;display:flex;gap:8px;}
.cbtn{background:none;border:none;color:var(--muted);font-size:.75rem;cursor:pointer;padding:2px 5px;border-radius:4px;transition:.2s;}
.cbtn:hover{background:var(--card);color:var(--text);}
.replies{border-left:2px solid var(--border);margin-left:36px;padding-left:14px;margin-top:8px;}
.reply-iw{display:flex;gap:7px;margin-top:7px;display:none;}
.reply-ta{flex:1;padding:7px 11px;background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);resize:none;font-family:inherit;font-size:.81rem;outline:none;min-height:52px;transition:.2s;}
.reply-ta:focus{border-color:var(--accent);}

/* ── UPLOAD & OTHER MODALS ── */
.umodal, .chmodal, .rmodal, .gate-overlay {
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.88);
  z-index:9001;justify-content:center;align-items:center;padding:16px;
}
.umodal.open, .chmodal.open, .rmodal.open, .gate-overlay.open {display:flex;}
.upanel, .chpanel, .rpanel, .gate-box {
  background:var(--card2);border:1px solid var(--border);
  border-radius:var(--radius-lg);width:100%;padding:24px;
  max-height:92vh;overflow-y:auto;
}
.upanel, .chpanel {max-width:500px;}
.rpanel {max-width:400px;}
.gate-box {max-width:360px;text-align:center;}
.upanel h2, .chpanel h2, .rpanel h3, .gate-box h2 {margin-bottom:20px;font-size:1.05rem;}
.fg{margin-bottom:13px;}
.fg label{display:block;font-size:.77rem;color:var(--muted);margin-bottom:5px;font-weight:500;}
input,textarea,select{width:100%;padding:10px 13px;background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);font-family:inherit;font-size:.85rem;outline:none;transition:.2s;}
input:focus,textarea:focus,select:focus{border-color:var(--accent);}
textarea{resize:vertical;min-height:66px;}
.tpill{display:inline-flex;align-items:center;gap:4px;background:rgba(108,99,255,.1);color:var(--accent);padding:3px 8px;border-radius:4px;font-size:.71rem;font-weight:600;margin:2px;cursor:pointer;}
.btn-pri{width:100%;padding:12px;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:none;border-radius:var(--radius-md);font-weight:700;cursor:pointer;font-size:.9rem;transition:.3s;margin-top:4px;}
.btn-pri:hover{opacity:.9;}
.btn-ghost-full{width:100%;padding:11px;background:var(--card);color:var(--muted);border:1px solid var(--border);border-radius:var(--radius-md);font-weight:600;cursor:pointer;font-size:.86rem;margin-top:7px;}
.btn-ghost-full:hover{color:var(--text);}
.tos-row{display:flex;align-items:flex-start;gap:10px;background:rgba(108,99,255,.06);border:1px solid rgba(108,99,255,.2);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:14px;}
.tos-row input[type=checkbox]{width:16px;height:16px;flex-shrink:0;margin-top:2px;accent-color:var(--accent);}
.tos-row label{font-size:.8rem;color:var(--muted);line-height:1.5;cursor:pointer;}
.gate-box p{color:var(--muted);font-size:.88rem;margin-bottom:22px;}

/* ── CHANNEL PAGE ── */
.ch-page{display:none;}
.ch-page.open{display:block;}
.ch-header{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:20px;}
.ch-banner{display:flex;align-items:flex-start;gap:18px;flex-wrap:wrap;}
.ch-av-big{width:60px;height:60px;border-radius:50%;object-fit:cover;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:700;color:#fff;flex-shrink:0;}
.ch-info{flex:1;}
.ch-name{font-size:1.2rem;font-weight:900;margin-bottom:4px;}
.ch-handle{color:var(--muted);font-size:.84rem;margin-bottom:8px;}
.ch-desc{color:var(--muted);font-size:.84rem;line-height:1.5;margin-bottom:10px;}
.ch-stats{display:flex;gap:20px;flex-wrap:wrap;}
.ch-stat{text-align:center;}
.ch-stat .n{font-weight:900;font-size:1.1rem;color:var(--accent);}
.ch-stat .l{color:var(--muted);font-size:.74rem;}
.ch-tabs{display:flex;gap:4px;background:var(--card);border-radius:11px;padding:4px;margin-bottom:18px;}
.ch-tab{flex:1;text-align:center;padding:8px;border-radius:var(--radius-sm);cursor:pointer;font-size:.83rem;font-weight:600;color:var(--muted);transition:.2s;border:none;background:none;}
.ch-tab.active{background:var(--accent);color:#fff;}

/* ── SPINNER ── */
.spin{display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:sp .7s linear infinite;vertical-align:middle;margin-right:5px;}
@keyframes sp{to{transform:rotate(360deg);}}

/* ═══════════════════════════════════
   TABLET  (≥ 768px)
═══════════════════════════════════ */
@media (min-width: 768px) {
  :root { --nav-h: 64px; }

  /* Show sidebar, adjust layout */
  .layout { flex-direction: row; min-height: calc(100vh - var(--nav-h)); }
  .sidebar {
    display: block;
    width: 210px;
    flex-shrink: 0;
    border-right: 1px solid var(--border);
    padding: 16px 10px;
    background: var(--bg2);
    position: sticky;
    top: var(--nav-h);
    height: calc(100vh - var(--nav-h));
    overflow-y: auto;
  }
  .main { padding: 20px 22px; }

  /* Sidebar styles */
  .sb-title{font-size:.7rem;font-weight:700;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;padding:0 8px;margin:14px 0 6px;}
  .sb-title:first-child{margin-top:0;}
  .sb-link{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);color:var(--muted);font-size:.83rem;cursor:pointer;transition:.2s;margin-bottom:2px;}
  .sb-link:hover,.sb-link.active{color:var(--text);background:var(--card);}
  .sb-cat{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:7px;color:var(--muted);font-size:.81rem;cursor:pointer;transition:.2s;margin-bottom:1px;}
  .sb-cat:hover,.sb-cat.active{color:var(--text);background:var(--card);}
  .cdot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}

  /* Subscribed channels in sidebar */
  .sb-sub-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:var(--radius-sm);color:var(--text);cursor:pointer;transition:.2s;margin-bottom:2px;}
  .sb-sub-item:hover{background:var(--card);}
  .sb-sub-av{width:24px;height:24px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--accent);}
  .sb-sub-av-ph{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:700;color:#fff;flex-shrink:0;}
  .sb-sub-info{flex:1;min-width:0;}
  .sb-sub-name{font-size:.81rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .sb-sub-meta{font-size:.68rem;color:var(--muted);}
  .sb-subs-empty{padding:6px 10px;font-size:.74rem;color:var(--muted);}

  .grid{grid-template-columns:repeat(auto-fill,minmax(255px,1fr));}
  .mp-body{padding:20px;}
  .ch-av-big{width:80px;height:80px;font-size:2rem;}
  .ch-name{font-size:1.4rem;}
  .vwrap{border-radius:var(--radius-md);}
}

@media (min-width: 900px) {
    .modal{padding: 32px;}
    .mpanel{margin:0 auto;}
}

/* ═══════════════════════════════════
   DESKTOP  (≥ 1024px)
═══════════════════════════════════ */
@media (min-width: 1024px) {
  :root { --nav-h: 70px; }
}

/* ═══════════════════
   REDUCED MOTION
═══════════════════ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ── Mobile-only Nav Buttons ── */
.mobile-nav-buttons {
  display: flex;
  gap: 6px;
  padding: 10px 16px;
  background: var(--card);
  border-bottom: 1px solid var(--border);
}
.mobile-nav-btn {
  flex: 1;
  padding: 10px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--card2);
  color: var(--muted);
  font-size: .8rem;
  font-weight: 600;
  cursor: pointer;
  transition: .2s;
  text-align: center;
}
.mobile-nav-btn.active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.mobile-nav-btn.primary {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
@media (min-width: 768px) {
  .mobile-nav-buttons { display: none; }
}

/* ── Sidebar Toggle Button (for mobile) ── */
.sidebar-toggle-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--card);
  border: 1px solid var(--border);
  color: var(--muted);
  padding: 4px 10px;
  border-radius: 20px;
  font-size: .75rem;
  font-weight: 600;
  cursor: pointer;
}
@media (min-width: 768px) {
  .sidebar-toggle-btn { display: none; }
}

/* ── Mobile Sidebar (Overlay) ── */
.mobile-sidebar-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.5);
  z-index: 850;
  display: none;
}
.mobile-sidebar-overlay.open { display: block; }
.mobile-sidebar {
  position: fixed;
  top: 0; left: 0; bottom: 0;
  width: 240px;
  background: var(--bg2);
  border-right: 1px solid var(--border);
  z-index: 851;
  transform: translateX(-100%);
  transition: transform .3s ease;
  padding: 16px 10px;
  overflow-y: auto;
}
.mobile-sidebar.open { transform: translateX(0); }
.mobile-sidebar .sb-title {
  font-size:.7rem;font-weight:700;color:var(--muted);letter-spacing:1.5px;
  text-transform:uppercase;padding:0 8px;margin:14px 0 6px;
}
.mobile-sidebar .sb-link, .mobile-sidebar .sb-cat {
  display:flex;align-items:center;gap:8px;padding:8px 10px;
  border-radius:var(--radius-sm);color:var(--muted);font-size:.83rem;
  cursor:pointer;transition:.2s;margin-bottom:2px;
}
.mobile-sidebar .sb-link:hover, .mobile-sidebar .sb-link.active,
.mobile-sidebar .sb-cat:hover, .mobile-sidebar .sb-cat.active {
  color:var(--text);background:var(--card);
}
.mobile-sidebar .cdot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.mobile-sidebar .sb-subs-empty{padding:6px 10px;font-size:.74rem;color:var(--muted);}
.mobile-sidebar .sb-sub-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:var(--radius-sm);color:var(--text);cursor:pointer;transition:.2s;margin-bottom:2px;}
.mobile-sidebar .sb-sub-item:hover{background:var(--card);}
.mobile-sidebar .sb-sub-av{width:24px;height:24px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--accent);}
.mobile-sidebar .sb-sub-av-ph{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:700;color:#fff;flex-shrink:0;}
.mobile-sidebar .sb-sub-info{flex:1;min-width:0;}
.mobile-sidebar .sb-sub-name{font-size:.81rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.mobile-sidebar .sb-sub-meta{font-size:.68rem;color:var(--muted);}