/* COLUMN BROWSER */
#pg-tut{flex-direction:row}
.cb{flex:1;display:flex;overflow:hidden}
.col{width:var(--col);min-width:var(--col);border-inline-start:1px solid var(--bor);
  display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}
.col:first-child{border-inline-start:none}
.ch{padding:7px 11px;font-size:11px;font-weight:600;color:var(--tx3);
  text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--bor);
  background:var(--sur);flex-shrink:0}
#h1{display:flex;align-items:center;gap:0}
.cb-body{flex:1;overflow-y:auto;overflow-x:hidden}
/* scrollbar always on inline-end (right in LTR, right in RTL) */
[dir="rtl"] .cb-body{direction:rtl}
[dir="ltr"] .cb-body{direction:ltr}
.cb-body .ci,.cb-body .vi,.cb-body .srhd{direction:inherit}
.ci{display:flex;align-items:center;padding:8px 11px;cursor:pointer;
  border-bottom:2px solid rgba(80,80,90,.35);transition:background .1s;gap:6px}
.ci:hover{background:var(--sur2)}
.ci.on{background:var(--acc);color:#fff}
.ci.on .cc,.ci.on .ca{color:rgba(255,255,255,.6)}
.ct{flex:1;font-size:13px;line-height:1.3}
.cc{font-size:11px;color:var(--tx3);flex-shrink:0}
.ca{color:var(--tx3);font-size:11px;flex-shrink:0}


/* ── MACRO CATEGORY COLUMN ─────────────────────────────────── */
#p-mc{flex-shrink:0}
#c-mc .ci.ci-bg{height:64px}
#c-mc .ci.ci-bg .ci-bg-txt{height:64px}
#c-mc .ci:not(.ci-bg){padding:9px 12px;font-size:12px;font-weight:600;
  text-transform:uppercase;letter-spacing:.5px}
#c-mc .ci.on{background:var(--acc);color:#fff}

/* ── THUMBNAIL POPUP ────────────────────────────────────────── */
#thumb-popup{position:fixed;z-index:9999;width:320px;border-radius:10px;
  overflow:hidden;pointer-events:none;opacity:0;transition:opacity .15s;
  border:0.5px solid rgba(255,255,255,.15);
  background:var(--bg);
  display:flex;flex-direction:row;align-items:stretch;gap:0}
#thumb-popup.visible{opacity:1}
#thumb-popup img{width:100px;min-width:100px;aspect-ratio:16/9;object-fit:cover;
  display:block;flex-shrink:0;border-radius:0;align-self:flex-start}
#thumb-popup .tp-body{padding:8px 10px 9px;flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}
#thumb-popup .tp-title{font-size:12px;font-weight:500;color:var(--tx);
  line-height:1.35;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
#thumb-popup .tp-ch{font-size:10px;color:var(--tx3);margin-top:1px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#thumb-popup .tp-meta{display:flex;gap:5px;align-items:center;flex-wrap:wrap;margin-top:2px}
#thumb-popup .tp-dur{font-size:10px;color:var(--tx3)}
#thumb-popup .tp-ydesc{font-size:10.5px;color:var(--tx2);line-height:1.45;margin-top:1px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
#thumb-popup .tp-sum{font-size:10px;line-height:1.4;margin-top:2px;
  border-top:1px solid rgba(124,58,237,.2);padding-top:4px;}
#thumb-popup .tp-sum-lbl{color:#a78bfa;font-weight:600;font-size:9.5px;
  text-transform:uppercase;letter-spacing:.04em;margin-right:4px}
#thumb-popup .tp-sum-txt{color:var(--tx3);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}


/* ── CATEGORY BACKGROUND IMAGES ─────────────────────────── */
.ci.ci-bg{position:relative;overflow:hidden;padding:0;height:68px;align-items:flex-end;background:#111}
.ci.ci-bg .ci-bg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center center;z-index:0;display:block;background:#0d0d0d;image-rendering:auto}
.ci.ci-bg .ci-bg-ov{position:absolute;inset:0;z-index:1;transition:opacity .2s;
  background:linear-gradient(to left,rgba(0,0,0,.90) 0%,rgba(0,0,0,.90) 50%,rgba(0,0,0,.45) 75%,rgba(0,0,0,.15) 100%)}
[dir=ltr] .ci.ci-bg .ci-bg-ov{
  background:linear-gradient(to right,rgba(0,0,0,.90) 0%,rgba(0,0,0,.90) 50%,rgba(0,0,0,.45) 75%,rgba(0,0,0,.15) 100%)}
.ci.ci-bg .ci-bg-ov2{position:absolute;inset:0;z-index:1;transition:opacity .2s}
.ci.ci-bg:hover .ci-bg-ov{opacity:0}
.ci.ci-bg:hover .ci-bg-ov2{
  background:
    url('/assets/glow.png') center bottom / 100% auto no-repeat,
    rgba(0,0,0,.12);
}
.ci.ci-bg.on .ci-bg-ov{opacity:1}
.ci.ci-bg.on .ci-bg-ov2{
  background:
    url('/assets/glow.png') center bottom / 100% auto no-repeat,
    linear-gradient(to top,rgba(74,0,255,.60) 0%,rgba(74,0,255,.45) 100%);
  mix-blend-mode:screen;
}
.ci.ci-bg .ci-bg-txt{position:relative;z-index:2;display:flex;align-items:center;
  width:100%;padding:0 11px;height:68px;gap:6px}
.ci.ci-bg .ct{color:#fff;font-size:12px;font-weight:500;text-shadow:0 1px 3px rgba(0,0,0,.6)}
.ci.ci-bg .cc{color:rgba(255,255,255,.55);font-size:10px}
.ci.ci-bg .ca{color:rgba(255,255,255,.4);font-size:11px}
.ci.ci-bg.on .ct{color:#d4ccff}
/* Macro header bg */
.mc-hd.mc-bg{position:relative;overflow:hidden;height:56px;padding:0;background:#111}
.mc-hd.mc-bg .mc-bg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0;background:#0d0d0d}
.mc-hd.mc-bg .mc-bg-ov{position:absolute;inset:0;z-index:1;transition:opacity .2s;
  background:linear-gradient(to left,rgba(0,0,0,.82) 0%,rgba(0,0,0,.82) 50%,rgba(0,0,0,.25) 75%,rgba(0,0,0,0) 100%)}
[dir=ltr] .mc-hd.mc-bg .mc-bg-ov{
  background:linear-gradient(to right,rgba(0,0,0,.82) 0%,rgba(0,0,0,.82) 50%,rgba(0,0,0,.25) 75%,rgba(0,0,0,0) 100%)}
.mc-hd.mc-bg .mc-bg-ov2{position:absolute;inset:0;z-index:1;transition:opacity .2s}
.mc-hd.mc-bg:hover .mc-bg-ov{opacity:0}
.mc-hd.mc-bg:hover .mc-bg-ov2{background:rgba(0,0,0,.1)}
.mc-hd.mc-bg .mc-bg-txt{position:relative;z-index:2;display:flex;align-items:center;
  width:100%;height:56px;padding:0 12px;gap:7px}
.mc-hd.mc-bg .mc-icon{font-size:14px}
.mc-hd.mc-bg .mc-title{color:#fff;flex:1;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px}
.mc-hd.mc-bg .mc-arrow{color:rgba(255,255,255,.7);font-size:18px !important}
.mc-hd.mc-bg .cc{color:rgba(255,255,255,.45)}

/* VIDEO LIST COL */
.col.vids{width:260px;min-width:260px}
.srhd{padding:5px 11px;font-size:11px;font-weight:600;color:var(--acc2);
  background:var(--sur);border-bottom:1px solid var(--bor)}
.vi{padding:8px 11px;cursor:pointer;border-bottom:1px solid var(--bor);transition:background .1s}
.vi:hover{background:var(--sur2)}
.vi.on{background:var(--sur2);border-right:3px solid var(--acc)}
.vt{font-size:12px;line-height:1.4;margin-bottom:2px;color:var(--tx)}
.vm{font-size:11px;color:var(--tx3);display:flex;gap:7px}
/* PLAYER */
#player{flex:1;overflow-y:auto;display:flex;flex-direction:column;min-width:0;transition:all .25s ease}

/* ── THEATER MODE ─────────────────────────────────────────── */
#pg-tut.theater .col{display:none !important}
#pg-tut.theater .col#p3{display:flex !important;width:220px;min-width:220px;flex-shrink:0}
#pg-tut.theater .col#p4.theater-show{display:flex !important;width:220px;min-width:220px;flex-shrink:0}
#pg-tut.theater #player{flex:1}
.pempty{flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;color:var(--tx3);gap:10px}
.pmeta{padding:14px 18px 10px;border-bottom:1px solid var(--bor);background:var(--sur)}
.ptitle{font-size:17px;font-weight:600;margin-bottom:3px}
.pchannel{font-size:12px;color:var(--tx3);margin-bottom:8px}
.pacts{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:8px}
.pact{display:flex;align-items:center;gap:4px;background:var(--sur2);
  border:1px solid var(--bor);border-radius:6px;padding:5px 9px;
  font-size:12px;color:var(--tx);transition:all .15s}
.pact:hover{border-color:var(--acc);color:var(--acc)}
.pact.on{background:var(--acc);border-color:var(--acc);color:#fff}
.ptags{display:flex;gap:5px;flex-wrap:wrap}
.tag{background:var(--sur2);border:1px solid var(--bor);
  border-radius:11px;padding:3px 9px;font-size:11px;color:var(--tx2)}
.tag.g{background:rgba(92,224,122,.1);border-color:rgba(92,224,122,.3);color:var(--green)}
.pembed{aspect-ratio:16/9;background:#000;flex-shrink:0}
.pembed iframe{width:100%;height:100%;border:none;display:block}
.psum{padding:14px 18px;line-height:1.75;color:var(--tx2);font-size:13px}
/* VIEW TOGGLE */
.vtog{display:flex;border:1px solid var(--bor);border-radius:6px;overflow:hidden;flex-shrink:0}
.vtbtn{background:none;border:none;padding:5px 11px;font-size:12px;color:var(--tx2);transition:all .15s}
.vtbtn.on{background:var(--acc);color:#fff}
.vtbtn:not(.on):hover{background:var(--sur2)}
/* EMPTY */
.epty{display:flex;flex-direction:column;align-items:center;justify-content:center;
  height:100%;color:var(--tx3);font-size:12px;gap:7px;text-align:center;padding:16px}
/* TOAST */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);
  background:var(--sur);border:1px solid var(--bor);border-radius:7px;
  padding:9px 16px;font-size:13px;box-shadow:0 4px 20px rgba(0,0,0,.4);
  z-index:9999;animation:tin .2s ease}
@keyframes tin{from{opacity:0;transform:translateX(-50%) translateY(7px)}}
/* ADD TUTORIAL BUTTON */
.add-tut-btn{display:flex;align-items:center;gap:7px;background:var(--acc);color:#fff;
  border:none;border-radius:8px;padding:9px 18px;font-size:14px;font-weight:600;
  cursor:pointer;transition:opacity .15s;flex-shrink:0}
.add-tut-btn:hover{opacity:.88}
.add-tut-btn svg{flex-shrink:0}
/* SUGGEST MODAL */
#sug-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:9996;align-items:center;justify-content:center}
#sug-modal.on{display:flex}
.sug-box{background:var(--bg);border:1px solid var(--bor);border-radius:12px;padding:22px;
  width:min(460px,94vw);display:flex;flex-direction:column;gap:13px}
.sug-box h3{font-size:15px;font-weight:600}
.sug-box input,.sug-box textarea,.sug-box select{background:var(--sur2);border:1px solid var(--bor);
  border-radius:6px;padding:8px 11px;font-size:13px;color:var(--tx);font-family:inherit;width:100%}
.sug-box input:focus,.sug-box textarea:focus{outline:none;border-color:var(--acc)}
/* USER AVATAR IN NAV */
.user-chip{display:flex;align-items:center;gap:7px;background:var(--sur2);
  border:1px solid var(--bor);border-radius:20px;padding:3px 10px 3px 3px;
  cursor:pointer;transition:all .15s;max-width:160px}
.user-chip:hover{border-color:var(--acc)}
.user-chip img{width:26px;height:26px;border-radius:50%;object-fit:cover;flex-shrink:0}
.user-chip span{font-size:12px;color:var(--tx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* HOME CTA BUTTON */
.home-cta-btn{font-size:14px;padding:9px 22px;background:var(--acc);color:#fff;
  border:none;border-radius:8px;cursor:pointer;font-weight:600;
  transition:filter .15s,transform .1s}
.home-cta-btn:hover{filter:brightness(1.15);transform:translateY(-1px)}
.mc-hd{display:flex;align-items:center;gap:7px;padding:9px 12px;
  background:var(--bg);border-bottom:2px solid var(--bor);border-top:1px solid var(--bor);
  cursor:pointer;user-select:none;position:sticky;top:0;z-index:2}
.mc-hd:first-child{border-top:none}
.mc-hd:hover{background:var(--sur2)}
.mc-icon{font-size:15px;flex-shrink:0}
.mc-title{flex:1;font-size:11px;font-weight:700;color:var(--tx);text-transform:uppercase;letter-spacing:.6px}
.mc-arrow{font-size:18px;color:var(--tx3);transition:transform .2s;font-weight:400}
.mc-body{overflow:hidden}
/* SOFTWARE GROUPS */
/* ── GROUP VISUAL SYSTEM ─────────────────────────────────── */
.sw-group-wrap { position: relative; margin-bottom: 2px; }
.sw-group-hd {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 12px; cursor: pointer; user-select: none;
  background: var(--sur2); border-bottom: 1px solid var(--bor);
  font-size: 12px; font-weight: 700; color: var(--tx);
  border-inline-start: 5px solid var(--group-color, #6b7280);
  transition: background .15s;
  position: relative;
}
.sw-group-hd:hover { background: var(--bor); }
.sw-group-hd.ci-bg { padding: 0 !important; min-height: 72px !important; height: 72px !important; background: var(--sur2) !important; }
.sw-group-hd.ci-bg .ci-bg-txt { padding: 0 12px; display: flex; align-items: center; gap: 8px; width: 100%; }
.sw-group-hd.ci-bg .ci-bg-txt .ct { font-size: 14px; font-weight: 700; color: #fff; flex: 1; }
.sw-group-hd.ci-bg .ci-bg-txt .cc { font-size: 11px; color: rgba(255,255,255,0.7); }
.sw-group-hd .sw-group-icon {
  width: 20px; height: 20px; object-fit: contain;
  border-radius: 3px; flex-shrink: 0;
}
.sw-group-hd .sw-group-icon-emoji { font-size: 16px; }
.sw-group-title { flex: 1; }
.sw-group-arrow { font-size: 11px; color: var(--tx3); transition: transform .2s; font-weight: 400; }
.sw-group-body { border-inline-start: 5px solid var(--group-color, #6b7280); }
.sw-group-body .ci { border-right: none !important; }
/* separator after group closes */
.sw-group-separator {
  height: 6px;
  background: linear-gradient(to bottom, var(--group-color, #6b7280) 0%, transparent 100%);
  opacity: 0.25;
  margin-bottom: 4px;
}
.sw-group-hd-btn { border-inline-start: 5px solid var(--group-color, #6b7280) !important; }
.psum-legal{font-size:11px;color:var(--tx3);text-align:center;padding:4px 0 8px;
  border-bottom:1px solid var(--bor);margin-bottom:8px}
/* DRAG REORDER */
.drag-handle{font-size:14px;color:var(--tx3);cursor:grab;padding:0 6px;flex-shrink:0;
  user-select:none;line-height:1;opacity:.5;transition:opacity .15s}
.drag-handle:hover{opacity:1;color:var(--acc)}
.drag-handle:active{cursor:grabbing}
.vi.drag-over{border-top:2px solid var(--acc);background:var(--sur2)}
.vi.dragging{opacity:.4}
/* FAVS */
#pg-favs{overflow-y:auto;padding:22px;flex-direction:column;gap:14px}
/* SW ICON */
.sw-icon{width:18px;height:18px;flex-shrink:0;border-radius:3px}
/* REPORT POPUP */
#rpt-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:9997;align-items:center;justify-content:center}
#rpt-modal.on{display:flex}
.rpt-box{background:var(--bg);border:1px solid var(--bor);border-radius:12px;padding:20px;width:min(440px,94vw);display:flex;flex-direction:column;gap:12px}
.rpt-box h3{font-size:14px;font-weight:600}
.rpt-box select,.rpt-box select+select{background:var(--sur2);border:1px solid var(--bor);border-radius:6px;padding:7px 10px;font-size:13px;color:var(--tx);width:100%}
.rpt-box textarea{background:var(--sur2);border:1px solid var(--bor);border-radius:6px;padding:8px 10px;font-size:13px;color:var(--tx);font-family:inherit;width:100%;min-height:55px;resize:vertical}
.rpt-actions{display:flex;gap:8px;justify-content:flex-end}
/* PLAYER TABS — below the video */
.ptabs{display:flex;border-bottom:1px solid var(--bor);border-top:1px solid var(--bor);background:var(--sur);flex-shrink:0}
.ptab{padding:9px 16px;font-size:13px;color:var(--tx2);border-bottom:2px solid transparent;
  background:none;border-top:none;border-left:none;border-right:none;cursor:pointer;transition:all .15s}
.ptab.on{color:var(--acc);border-bottom-color:var(--acc);font-weight:600}
.ptab:hover:not(.on){color:var(--tx);background:var(--sur2)}
.ppanel{display:none;padding:14px 18px;flex-direction:column;gap:10px;overflow-y:auto}
.ppanel.on{display:flex}
/* NOTES */
.notes-ta{width:100%;min-height:90px;resize:vertical;background:var(--sur2);
  border:1px solid var(--bor);border-radius:6px;padding:9px 11px;font-size:13px;
  color:var(--tx);font-family:inherit;line-height:1.5}
.notes-ta:focus{outline:none;border-color:var(--acc)}
.notes-save{align-self:flex-end;background:var(--acc);color:#fff;border:none;
  border-radius:6px;padding:6px 14px;font-size:12px;cursor:pointer;transition:opacity .15s}
.notes-save:hover{opacity:.85}
/* COMMENTS */
.cmts{display:flex;flex-direction:column;gap:10px}
.cmt{background:var(--sur2);border:1px solid var(--bor);border-radius:8px;padding:10px 12px}
.cmt-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}
.cmt-name{font-size:12px;font-weight:600;color:var(--acc2)}
.cmt-time{font-size:10px;color:var(--tx3)}
.cmt-body{font-size:13px;line-height:1.5;color:var(--tx)}
.cmt-input{display:flex;gap:7px;align-items:flex-end}
.cmt-ta{flex:1;min-height:60px;resize:vertical;background:var(--sur2);
  border:1px solid var(--bor);border-radius:6px;padding:8px 10px;font-size:13px;
  color:var(--tx);font-family:inherit}
.cmt-ta:focus{outline:none;border-color:var(--acc)}
.cmt-send{background:var(--acc);color:#fff;border:none;border-radius:6px;
  padding:8px 13px;font-size:12px;cursor:pointer;white-space:nowrap;align-self:flex-end}
.cmt-login{font-size:12px;color:var(--tx3);text-align:center;padding:10px}
/* ── DARK SCROLLBAR ──────────────────────────────────────── */
*{scrollbar-width:thin;scrollbar-color:#444 #111}
*::-webkit-scrollbar{width:6px;height:6px}
*::-webkit-scrollbar-track{background:#111;border-radius:3px}
*::-webkit-scrollbar-thumb{background:#484848;border-radius:3px;border:1px solid #111}
*::-webkit-scrollbar-thumb:hover{background:#666}
*::-webkit-scrollbar-corner{background:#111}
/* Column bodies — slightly more visible thumb */
.cb-body::-webkit-scrollbar-thumb{background:#555}
.cb-body::-webkit-scrollbar-track{background:#161616}
.srch-item-path{font-size:10px;color:var(--tx3);margin-top:2px;opacity:.7;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* ── SEARCH DROPDOWN ─────────────────────────────────────── */
#srch-drop{position:fixed;top:52px;left:0;
  width:min(520px,90vw);max-height:70vh;overflow-y:auto;
  background:var(--sur);border:1px solid var(--bor);border-radius:0 0 10px 10px;
  box-shadow:0 12px 40px rgba(0,0,0,.5);z-index:200;display:none;flex-direction:column}
#srch-drop.open{display:flex}
.srch-drop-head{padding:6px 12px;border-bottom:1px solid var(--bor);
  display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center;flex-shrink:0}
.srch-drop-filters{display:flex;gap:5px;flex-wrap:wrap;justify-content:center}
.srch-drop-count{font-size:12px;color:var(--tx3);flex:1}
.srch-filter-btn{font-size:11px;padding:3px 9px;border-radius:99px;border:1px solid var(--bor);
  background:none;color:var(--tx2);cursor:pointer;transition:all .15s;white-space:nowrap}
.srch-filter-btn.on{background:var(--acc);border-color:var(--acc);color:#fff}
.srch-filter-btn:hover:not(.on){background:var(--sur2);color:var(--tx)}
.srch-body{padding:6px 0;flex:1}
.srch-item{display:flex;align-items:center;gap:10px;padding:7px 14px;cursor:pointer;
  border-bottom:1px solid rgba(255,255,255,.04);transition:background .1s}
.srch-item:hover{background:var(--sur2)}
.srch-item-thumb{width:64px;height:36px;border-radius:4px;object-fit:cover;flex-shrink:0;background:var(--sur2)}
.srch-item-info{flex:1;min-width:0}
.srch-item-title{font-size:12px;font-weight:500;color:var(--tx);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}
.srch-item-meta{font-size:11px;color:var(--tx3);display:flex;gap:6px;align-items:center}
.srch-item-sw{color:var(--acc2);font-weight:500}
.srch-no-results{padding:24px;text-align:center;color:var(--tx3);font-size:13px}
#pg-admin{overflow-y:auto;padding:22px;flex-direction:column;gap:20px}
#pg-search.on{display:flex !important}
#pg-history.on{display:flex !important}
.adm-section{background:var(--sur);border:1px solid var(--bor);border-radius:10px;padding:16px}
.adm-section h3{font-size:14px;font-weight:600;margin-bottom:12px;color:var(--tx)}
.adm-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--bor);font-size:13px}
.adm-row:last-child{border-bottom:none}
.adm-badge{font-size:10px;padding:2px 7px;border-radius:10px;background:var(--acc);color:#fff}
/* ADMIN VIDEO EDITOR MODAL */
#adm-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:9998;
  align-items:center;justify-content:center}
#adm-modal.on{display:flex}
.adm-modal-box{background:var(--bg);border:1px solid var(--bor);border-radius:12px;
  padding:22px;width:min(520px,95vw);max-height:85vh;overflow-y:auto;display:flex;flex-direction:column;gap:14px}
.adm-modal-box h3{font-size:15px;font-weight:600}
.adm-field{display:flex;flex-direction:column;gap:5px}
.adm-field label{font-size:11px;color:var(--tx3);text-transform:uppercase;letter-spacing:.5px}
.adm-field input,.adm-field select,.adm-field textarea{background:var(--sur2);
  border:1px solid var(--bor);border-radius:6px;padding:8px 10px;font-size:13px;
  color:var(--tx);font-family:inherit;width:100%}
.adm-field input:focus,.adm-field select:focus,.adm-field textarea:focus{outline:none;border-color:var(--acc)}
.adm-modal-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}
.adm-btn{padding:7px 16px;border-radius:6px;font-size:13px;cursor:pointer;border:1px solid var(--bor)}
.adm-btn.primary{background:var(--acc);color:#fff;border-color:var(--acc)}
.adm-btn:not(.primary){background:var(--sur2);color:var(--tx)}

/* ── GLOW on plain (no-image) buttons: hover + selected ──── */
.ci:not(.ci-bg) {
  position: relative;
  overflow: hidden;
}
.ci:not(.ci-bg)::after {
  content: '';
  position: absolute;
  inset: 0;
  background: url('/assets/glow.png') center bottom / 100% auto no-repeat;
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s;
  mix-blend-mode: screen;
}
.ci:not(.ci-bg):hover::after {
  opacity: 1;
}
.ci:not(.ci-bg).on::after {
  opacity: 1;
}
/* plain .on — keep existing purple bg + glow on top */
.ci:not(.ci-bg).on {
  background: rgba(74,0,255,.55) !important;
}
#c-mc .ci:not(.ci-bg).on {
  background: rgba(74,0,255,.55) !important;
}

/* ── COLUMN BREADCRUMBS + LAYOUT RESTRUCTURE ─────────────── */
/* pg-tut is now column-direction: breadcrumbs on top, tut-body below */
#pg-tut { flex-direction: column !important; }
#tut-body { flex: 1; display: flex; flex-direction: row; overflow: hidden; min-height: 0; }
#tut-body::-webkit-scrollbar { height: 0; display: none; }

/* Breadcrumbs bar */
#col-breadcrumbs {
  padding: 4px 14px;
  border-bottom: 1px solid var(--bor);
  background: var(--sur);
  display: flex;
  align-items: center;
  gap: 3px;
  flex-wrap: wrap;
  flex-shrink: 0;
  min-height: 28px;
  font-size: 11px;
  direction: rtl;
}
#col-breadcrumbs:empty { display: none; }
.cb-item {
  color: var(--acc2);
  cursor: pointer;
  padding: 1px 4px;
  border-radius: 4px;
  transition: background .12s;
}
.cb-item:hover { background: var(--sur2); }
.cb-sep { color: var(--tx3); opacity: .5; user-select: none; }
.cb-current { color: var(--tx2); }
/* ── Column overflow: auto-scroll to newest column (JS-driven) ────────── */
/* Columns (flex-shrink:0) overflow tut-body; JS scrolls to newest column */
#tut-body { overflow-x: auto; overflow-y: hidden; scrollbar-width: none; }
#tut-body::-webkit-scrollbar { display: none; }

/* ── Series Panel (below video) ───────────────────────────────────────── */
#pseries-panel {
  border-top: 1px solid var(--bor);
  background: var(--sur);
  padding: 14px 16px;
  flex-shrink: 0;
}
.sp-next-cta {
  display: flex; align-items: center; gap: 12px;
  background: var(--acc); color: #fff;
  border-radius: 10px; padding: 10px 14px;
  cursor: pointer; margin-bottom: 14px;
  transition: opacity .15s;
}
.sp-next-cta:hover { opacity: .88; }
.sp-next-thumb {
  width: 90px; height: 51px; flex-shrink: 0;
  border-radius: 6px; object-fit: cover;
  background: #000;
}
.sp-next-info { flex: 1; min-width: 0; }
.sp-next-label {
  font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .6px;
  opacity: .85; margin-bottom: 3px;
}
.sp-next-title {
  font-size: 13px; font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sp-next-arrow { font-size: 20px; flex-shrink: 0; opacity: .9; }
.sp-series-header {
  font-size: 11px; color: var(--tx2); font-weight: 600;
  margin-bottom: 8px; padding-bottom: 6px;
  border-bottom: 1px solid var(--bor);
}
.sp-ep-list {
  display: flex; flex-direction: column; gap: 4px;
  max-height: 240px; overflow-y: auto;
}
.sp-ep-item {
  display: flex; align-items: center; gap: 9px;
  padding: 5px 7px; border-radius: 7px; cursor: pointer;
  transition: background .12s; position: relative;
}
.sp-ep-item:hover { background: var(--sur2); }
.sp-ep-item.active {
  background: var(--sur2);
  outline: 2px solid var(--acc);
  outline-offset: -2px;
}
.sp-ep-thumb {
  width: 72px; height: 41px; flex-shrink: 0;
  border-radius: 5px; object-fit: cover; background: #000;
  position: relative;
}
.sp-ep-playing {
  position: absolute; inset: 0; background: rgba(0,0,0,.55);
  border-radius: 5px; display: flex; align-items: center;
  justify-content: center; font-size: 16px; color: #fff;
}
.sp-ep-meta { flex: 1; min-width: 0; }
.sp-ep-num { font-size: 10px; color: var(--tx3); margin-bottom: 2px; }
.sp-ep-title {
  font-size: 12px; color: var(--tx1); font-weight: 500;
  display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
}
.sp-ep-dur { font-size: 10px; color: var(--tx3); margin-top: 2px; }
/* Tooltip (reuses existing .vi-tip if any, else standalone) */
.sp-tip {
  position: absolute; z-index: 9999; bottom: calc(100% + 8px);
  left: 50%; transform: translateX(-50%);
  background: var(--bg); border: 1px solid var(--bor);
  border-radius: 8px; padding: 8px 10px; width: 220px;
  box-shadow: 0 4px 16px rgba(0,0,0,.18);
  pointer-events: none; display: none;
}
.sp-ep-item:hover .sp-tip { display: block; }
.sp-tip-title { font-size: 12px; font-weight: 600; color: var(--tx1); margin-bottom: 4px; }
.sp-tip-sum { font-size: 11px; color: var(--tx2); line-height: 1.4; }
.sp-tip-meta { font-size: 10px; color: var(--tx3); margin-top: 4px; display: flex; gap: 8px; }

/* ══════════════════════════════════════════════════════════
   SERIES PANEL v2 — Horizontal layout with collapse toggle
   ════════════════════════════════════════════════════════ */
#pseries-panel {
  border-top: 1px solid var(--bor) !important;
  background: var(--sur) !important;
  flex-shrink: 0 !important;
  overflow: hidden !important;
  padding: 0 !important;
  transition: max-height .28s ease !important;
  max-height: 190px !important;
}
#pseries-panel.sp-collapsed { max-height: 38px !important; }

/* ── Header bar ─────────────────────────── */
.sp-header {
  display: flex !important; align-items: center; gap: 8px;
  padding: 7px 13px; border-bottom: 1px solid var(--bor);
  height: 38px; flex-shrink: 0; box-sizing: border-box;
}
.sp-header-icon { font-size: 13px; opacity: .65; flex-shrink: 0; }
.sp-header-title {
  flex: 1; font-size: 11px; font-weight: 600; color: var(--tx2);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sp-header-count { font-size: 10px; color: var(--tx3); flex-shrink: 0; }
.sp-toggle {
  background: var(--sur2); border: 1px solid var(--bor);
  border-radius: 5px; padding: 0 8px; height: 22px;
  font-size: 16px; color: var(--tx2); cursor: pointer;
  line-height: 22px; transition: background .12s; user-select: none;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-weight: 300;
}
.sp-toggle:hover { background: var(--bor); color: var(--tx); }

/* ── Horizontal scroll row ──────────────── */
.sp-scroll {
  display: flex !important; gap: 8px; padding: 9px 12px;
  overflow-x: auto; scroll-snap-type: x mandatory;
  scrollbar-width: thin; scrollbar-color: #555 transparent;
  align-items: flex-start;
}
.sp-scroll::-webkit-scrollbar { height: 3px; }
.sp-scroll::-webkit-scrollbar-thumb { background: #555; border-radius: 2px; }

/* ── Episode card base ──────────────────── */
.sp-card {
  flex-shrink: 0; cursor: pointer; scroll-snap-align: start;
  border-radius: 8px; overflow: hidden;
  background: var(--sur2); border: 1.5px solid var(--bor);
  transition: border-color .15s, transform .12s, opacity .15s;
  width: 126px;
}
.sp-card:hover { border-color: var(--acc); transform: translateY(-2px); }
.sp-card.sp-active {
  border-color: var(--acc);
  box-shadow: 0 0 0 2px rgba(100,60,255,.25);
}
.sp-card.sp-past { opacity: .5; }
.sp-card.sp-past:hover { opacity: .85; }

/* ── Next episode card — wider + highlighted ── */
.sp-card.sp-next-card {
  width: 178px;
  border-color: var(--acc);
  background: rgba(74,0,255,.08);
}
.sp-card.sp-next-card:hover { transform: translateY(-2px); filter: brightness(1.07); }

/* ── Thumbnail ──────────────────────────── */
.sp-card-thumb-wrap { position: relative; width: 100%; }
.sp-card-thumb {
  width: 100%; aspect-ratio: 16/9;
  object-fit: cover; display: block; background: #111;
}
.sp-card-next-badge {
  position: absolute; bottom: 5px; right: 5px;
  background: var(--acc); color: #fff;
  font-size: 9px; font-weight: 700; padding: 2px 6px;
  border-radius: 4px; letter-spacing: .3px;
}
.sp-card-playing-ov {
  position: absolute; inset: 0; background: rgba(0,0,0,.5);
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; color: #fff;
}

/* ── Card text ──────────────────────────── */
.sp-card-meta { padding: 6px 8px 7px; }
.sp-card-ep { font-size: 9px; color: var(--tx3); margin-bottom: 2px; }
.sp-card-title {
  font-size: 11px; color: var(--tx); font-weight: 500;
  line-height: 1.35;
  display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
}
.sp-card-dur { font-size: 9px; color: var(--tx3); margin-top: 3px; }

/* ══════════════════════════════════════════════════════════
   SERIES PANEL v3 — fixes: header, smaller cards, scroll, chevron
   ════════════════════════════════════════════════════════ */

/* Panel container */
#pseries-panel {
  border-top: 2px solid var(--acc) !important;
  background: var(--bg) !important;
  flex-shrink: 0 !important;
  overflow: hidden !important;
  padding: 0 !important;
  transition: max-height .28s ease !important;
  max-height: 172px !important;
}
#pseries-panel.sp-collapsed { max-height: 40px !important; }

/* Header — prominent "WATCH NEXT" bar */
.sp-header {
  display: flex !important; align-items: center; gap: 10px;
  padding: 0 13px; height: 40px; flex-shrink: 0; box-sizing: border-box;
  background: rgba(74,0,255,.12);
  border-bottom: 1px solid rgba(74,0,255,.25);
  cursor: pointer;
  user-select: none;
}
.sp-header:hover { background: rgba(74,0,255,.18); }
.sp-header-icon { font-size: 13px; opacity: .8; flex-shrink: 0; color: var(--acc2); }
.sp-header-label {
  font-size: 11px; font-weight: 800; letter-spacing: .8px;
  text-transform: uppercase; color: var(--acc2); flex-shrink: 0;
}
.sp-header-title {
  flex: 1; font-size: 10px; color: var(--tx3); font-weight: 400;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  padding-inline-start: 6px;
}
.sp-header-count { font-size: 10px; color: var(--tx3); flex-shrink: 0; }
.sp-toggle {
  background: rgba(74,0,255,.15); border: 1px solid rgba(74,0,255,.35);
  border-radius: 6px; padding: 0 9px; height: 26px;
  font-size: 13px; color: var(--acc2); cursor: pointer;
  line-height: 26px; transition: background .12s; user-select: none;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.sp-toggle:hover { background: rgba(74,0,255,.30); }

/* Horizontal scroll row */
.sp-scroll {
  display: flex !important; gap: 7px; padding: 8px 11px;
  overflow-x: auto !important; scroll-snap-type: x mandatory;
  scrollbar-width: thin; scrollbar-color: #555 transparent;
  align-items: flex-start; max-height: 132px; box-sizing: border-box;
}
.sp-scroll::-webkit-scrollbar { height: 3px; }
.sp-scroll::-webkit-scrollbar-thumb { background: #555; border-radius: 2px; }

/* Base card — smaller */
.sp-card {
  flex-shrink: 0; cursor: pointer; scroll-snap-align: start;
  border-radius: 7px; overflow: hidden;
  background: var(--sur2); border: 1.5px solid var(--bor);
  transition: border-color .15s, transform .12s, opacity .15s;
  width: 105px;
}
.sp-card:hover { border-color: var(--acc); transform: translateY(-2px); }
.sp-card.sp-active {
  border-color: var(--acc);
  box-shadow: 0 0 0 2px rgba(100,60,255,.25);
}
.sp-card.sp-past { opacity: .45; }
.sp-card.sp-past:hover { opacity: .8; }

/* Next card — slightly wider */
.sp-card.sp-next-card {
  width: 148px;
  border-color: var(--acc);
  background: rgba(74,0,255,.08);
}

/* Thumbnails — smaller */
.sp-card-thumb-wrap { position: relative; width: 100%; }
.sp-card-thumb {
  width: 100%; aspect-ratio: 16/9;
  object-fit: cover; display: block; background: #111;
}
.sp-card-next-badge {
  position: absolute; bottom: 4px; right: 4px;
  background: var(--acc); color: #fff;
  font-size: 8px; font-weight: 700; padding: 1px 5px;
  border-radius: 3px; letter-spacing: .3px;
}
.sp-card-playing-ov {
  position: absolute; inset: 0; background: rgba(0,0,0,.5);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; color: #fff;
}

/* Card text */
.sp-card-meta { padding: 4px 6px 5px; }
.sp-card-ep { font-size: 8px; color: var(--tx3); margin-bottom: 1px; }
.sp-card-title {
  font-size: 10px; color: var(--tx); font-weight: 500;
  line-height: 1.3;
  display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
}
.sp-card-dur { font-size: 8px; color: var(--tx3); margin-top: 2px; }

/* ══════════════════════════════════════════════════════════
   SERIES PANEL v4 — centered header, compact cards, no vertical scroll
   ════════════════════════════════════════════════════════ */

/* Header — centered, wide toggle button */
.sp-header {
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 0 14px;
  height: 40px;
  flex-shrink: 0;
  box-sizing: border-box;
  background: rgba(74,0,255,.12);
  border-bottom: 1px solid rgba(74,0,255,.25);
  cursor: pointer;
  user-select: none;
}
.sp-header:hover { background: rgba(74,0,255,.18); }
.sp-header-icon { font-size: 12px; opacity: .7; color: var(--acc2); flex-shrink: 0; }
.sp-header-label {
  font-size: 11px; font-weight: 800; letter-spacing: .8px;
  text-transform: uppercase; color: var(--acc2); flex-shrink: 0;
}
/* hide old title/count — just WATCH NEXT + chevron */
.sp-header-title { display: none !important; }
.sp-header-count { display: none !important; }
.sp-toggle {
  background: rgba(74,0,255,.2);
  border: 1px solid rgba(74,0,255,.4);
  border-radius: 6px;
  padding: 0 16px;  /* wider — 2x */
  height: 24px;
  font-size: 13px; color: var(--acc2); cursor: pointer;
  line-height: 24px; transition: background .12s;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; min-width: 48px;
}
.sp-toggle:hover { background: rgba(74,0,255,.35); }

/* Panel height — no vertical scroll */
#pseries-panel {
  border-top: 2px solid var(--acc) !important;
  background: var(--bg) !important;
  flex-shrink: 0 !important;
  overflow: hidden !important;
  padding: 0 !important;
  transition: max-height .28s ease !important;
  max-height: 158px !important;  /* header 40 + scroll row 118 */
}
#pseries-panel.sp-collapsed { max-height: 40px !important; }

/* Scroll row — fixed height, no vertical overflow */
.sp-scroll {
  display: flex !important;
  gap: 7px;
  padding: 8px 11px;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  scroll-snap-type: x mandatory;
  scrollbar-width: thin;
  scrollbar-color: #555 transparent;
  align-items: flex-start;
  height: 118px;
  box-sizing: border-box;
}
.sp-scroll::-webkit-scrollbar { height: 3px; }
.sp-scroll::-webkit-scrollbar-thumb { background: #555; border-radius: 2px; }

/* Cards — compact, duration above title */
.sp-card {
  flex-shrink: 0; cursor: pointer; scroll-snap-align: start;
  border-radius: 7px; overflow: hidden;
  background: var(--sur2); border: 1.5px solid var(--bor);
  transition: border-color .15s, transform .12s, opacity .15s;
  width: 105px;
  display: flex; flex-direction: column;
}
.sp-card:hover { border-color: var(--acc); transform: translateY(-2px); }
.sp-card.sp-active { border-color: var(--acc); box-shadow: 0 0 0 2px rgba(100,60,255,.25); }
.sp-card.sp-past { opacity: .45; }
.sp-card.sp-past:hover { opacity: .8; }
.sp-card.sp-next-card { width: 148px; border-color: var(--acc); background: rgba(74,0,255,.08); }

/* Thumbnail */
.sp-card-thumb-wrap { position: relative; width: 100%; flex-shrink: 0; }
.sp-card-thumb { width: 100%; aspect-ratio: 16/9; object-fit: cover; display: block; background: #111; }
.sp-card-next-badge {
  position: absolute; bottom: 4px; right: 4px;
  background: var(--acc); color: #fff;
  font-size: 8px; font-weight: 700; padding: 1px 5px;
  border-radius: 3px;
}
.sp-card-playing-ov {
  position: absolute; inset: 0; background: rgba(0,0,0,.5);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; color: #fff;
}

/* Card meta — ep number + duration on same row, title below */
.sp-card-meta { padding: 4px 6px 4px; flex: 1; min-width: 0; }
.sp-card-top-row {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 2px;
}
.sp-card-ep { font-size: 8px; color: var(--tx3); }
.sp-card-dur { font-size: 8px; color: var(--tx3); }
.sp-card-title {
  font-size: 10px; color: var(--tx); font-weight: 500;
  line-height: 1.3;
  display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
}

/* ── Episode relevance badge ─────────────────────────────── */
.sp-card-relevant {
  border-color: var(--acc) !important;
}
.sp-card-relevant .sp-card-thumb-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  outline: 2px solid var(--acc);
  outline-offset: -2px;
  border-radius: 0;
  pointer-events: none;
}
.sp-ep-tag {
  display: inline-block;
  font-size: 7px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .3px;
  padding: 1px 4px; border-radius: 3px;
  background: var(--acc); color: #fff;
  margin-top: 2px; line-height: 1.4;
  max-width: 100%; overflow: hidden;
  text-overflow: ellipsis; white-space: nowrap;
}
.sp-ep-tag.sp-tag-other {
  background: var(--sur2);
  color: var(--tx3);
  border: 1px solid var(--bor);
}

/* ══════════════════════════════════════════════════════════
   SERIES PANEL v5 — topic badge, fixed height, SVG chevron
   ════════════════════════════════════════════════════════ */

/* Fixed panel height — enough to show full cards */
#pseries-panel {
  border-top: 2px solid var(--acc) !important;
  background: var(--bg) !important;
  flex-shrink: 0 !important;
  overflow: hidden !important;
  padding: 0 !important;
  transition: max-height .28s ease !important;
  max-height: 196px !important;  /* 40 header + 156 scroll */
}
#pseries-panel.sp-collapsed { max-height: 40px !important; }

/* Header — text only, no icon */
.sp-header {
  display: flex !important; align-items: center;
  justify-content: center; gap: 10px;
  padding: 0 14px; height: 40px;
  flex-shrink: 0; box-sizing: border-box;
  background: rgba(74,0,255,.12);
  border-bottom: 1px solid rgba(74,0,255,.25);
  cursor: pointer; user-select: none;
}
.sp-header:hover { background: rgba(74,0,255,.18); }
.sp-header-icon { display: none !important; }
.sp-header-label {
  font-size: 11px; font-weight: 800; letter-spacing: .8px;
  text-transform: uppercase; color: var(--acc2); flex-shrink: 0;
}
.sp-header-title { display: none !important; }
.sp-header-count { display: none !important; }

/* SVG chevron toggle button */
.sp-toggle {
  background: rgba(74,0,255,.2);
  border: 1px solid rgba(74,0,255,.4);
  border-radius: 6px; padding: 0 14px; height: 26px;
  color: var(--acc2); cursor: pointer;
  transition: background .12s;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; min-width: 48px;
}
.sp-toggle:hover { background: rgba(74,0,255,.35); }
.sp-chevron {
  display: block;
  transition: transform .22s ease;
  stroke: var(--acc2);
}
#pseries-panel.sp-collapsed .sp-chevron {
  transform: rotate(180deg);
}

/* Scroll row — fixed height, full card visible */
.sp-scroll {
  display: flex !important; gap: 7px; padding: 8px 11px;
  overflow-x: auto !important; overflow-y: hidden !important;
  scroll-snap-type: x mandatory;
  scrollbar-width: thin; scrollbar-color: #555 transparent;
  align-items: flex-start;
  height: 156px; box-sizing: border-box;
}
.sp-scroll::-webkit-scrollbar { height: 3px; }
.sp-scroll::-webkit-scrollbar-thumb { background: #555; border-radius: 2px; }

/* Cards */
.sp-card {
  flex-shrink: 0; cursor: pointer; scroll-snap-align: start;
  border-radius: 7px; overflow: hidden;
  background: var(--sur2); border: 1.5px solid var(--bor);
  transition: border-color .15s, transform .12s, opacity .15s;
  width: 108px;
  display: flex; flex-direction: column;
}
.sp-card:hover { border-color: var(--acc); transform: translateY(-2px); }
.sp-card.sp-active { border-color: var(--acc); box-shadow: 0 0 0 2px rgba(100,60,255,.25); }
.sp-card.sp-past { opacity: .45; }
.sp-card.sp-past:hover { opacity: .8; }
.sp-card.sp-next-card {
  width: 152px; border-color: var(--acc);
  background: rgba(74,0,255,.08);
}

/* Thumbnail */
.sp-card-thumb-wrap { position: relative; width: 100%; flex-shrink: 0; }
.sp-card-thumb {
  width: 100%; aspect-ratio: 16/9;
  object-fit: cover; display: block; background: #111;
}
.sp-card-next-badge {
  position: absolute; bottom: 4px; right: 4px;
  background: var(--acc); color: #fff;
  font-size: 8px; font-weight: 700; padding: 1px 5px;
  border-radius: 3px;
}
.sp-card-playing-ov {
  position: absolute; inset: 0; background: rgba(0,0,0,.5);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; color: #fff;
}

/* Topic badge — overlaid on thumbnail, bottom-left */
.sp-topic-badge {
  position: absolute; bottom: 0; left: 0;
  font-size: 7px; font-weight: 800;
  text-transform: uppercase; letter-spacing: .3px;
  padding: 2px 6px; line-height: 1.5;
  max-width: 90%; overflow: hidden;
  text-overflow: ellipsis; white-space: nowrap;
  border-radius: 0 4px 0 0;
}
.sp-topic-badge.sp-badge-here {
  background: var(--acc); color: #fff;
}
.sp-topic-badge.sp-badge-other {
  background: rgba(0,0,0,.72); color: rgba(255,255,255,.75);
}

/* Card text */
.sp-card-meta { padding: 5px 7px 6px; flex: 1; min-width: 0; }
.sp-card-top-row {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 3px;
}
.sp-card-ep { font-size: 8px; color: var(--tx3); }
.sp-card-dur { font-size: 8px; color: var(--tx3); }
.sp-card-title {
  font-size: 10px; color: var(--tx); font-weight: 500;
  line-height: 1.35;
  display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
}

/* ══════════════════════════════════════════════════════════
   SERIES PANEL v6 — unified wide toggle button with chevron
   ════════════════════════════════════════════════════════ */

/* Full-width single toggle button — replaces header */
#pseries-panel {
  border-top: 2px solid var(--acc) !important;
  background: var(--bg) !important;
  flex-shrink: 0 !important;
  overflow: hidden !important;
  padding: 0 !important;
  transition: max-height .28s ease !important;
  max-height: 196px !important;
}
#pseries-panel.sp-collapsed { max-height: 40px !important; }

/* Header = one wide button */
.sp-header {
  display: flex !important; align-items: center;
  justify-content: center; gap: 10px;
  padding: 0 16px; height: 40px;
  width: 100%; box-sizing: border-box;
  background: rgba(74,0,255,.14);
  border-bottom: 1px solid rgba(74,0,255,.28);
  cursor: pointer; user-select: none;
  border: none; outline: none;
  transition: background .12s;
}
.sp-header:hover { background: rgba(74,0,255,.24); }
.sp-header:active { background: rgba(74,0,255,.35); }

.sp-header-icon  { display: none !important; }
.sp-header-title { display: none !important; }
.sp-header-count { display: none !important; }

.sp-header-label {
  font-size: 11px; font-weight: 800;
  letter-spacing: .9px; text-transform: uppercase;
  color: var(--acc2); flex-shrink: 0;
}

/* Chevron inside the header button */
.sp-toggle {
  display: flex !important; align-items: center; justify-content: center;
  background: none !important; border: none !important;
  padding: 0 !important; margin: 0 !important;
  cursor: pointer; flex-shrink: 0;
  width: 22px; height: 22px;
  pointer-events: none;  /* click handled by header */
}
.sp-chevron {
  display: block;
  stroke: var(--acc2);
  transition: transform .22s ease;
}
#pseries-panel.sp-collapsed .sp-chevron {
  transform: rotate(180deg);
}

/* Scroll row */
.sp-scroll {
  display: flex !important; gap: 7px; padding: 8px 11px;
  overflow-x: auto !important; overflow-y: hidden !important;
  scroll-snap-type: x mandatory;
  scrollbar-width: thin; scrollbar-color: #555 transparent;
  align-items: flex-start;
  height: 156px; box-sizing: border-box;
}
.sp-scroll::-webkit-scrollbar { height: 3px; }
.sp-scroll::-webkit-scrollbar-thumb { background: #555; border-radius: 2px; }

/* ══════════════════════════════════════════════════════════
   SERIES PANEL v7 — fix chevron SVG, bigger height, no cutoff
   ════════════════════════════════════════════════════════ */
#pseries-panel {
  max-height: 210px !important;  /* +14px: header 40 + scroll 170 */
}
#pseries-panel.sp-collapsed { max-height: 40px !important; }

.sp-scroll {
  height: 170px !important;
  box-sizing: border-box;
  padding: 8px 11px 6px !important;
}

/* Next card — taller to fit 2-line title */
.sp-card.sp-next-card {
  width: 155px;
}
.sp-card-title {
  -webkit-line-clamp: 3 !important;  /* allow 3 lines */
  font-size: 10px;
}
.sp-card-meta {
  padding: 5px 7px 5px !important;
}

/* Toggle button inside header — pointer-events:none so click goes to header */
.sp-toggle { pointer-events: none !important; }

/* ══ Series Panel v8 — next card = same width as others ══ */
.sp-card.sp-next-card {
  width: 108px !important;  /* same as regular cards */
  background: rgba(74,0,255,.08);
  border-color: var(--acc);
}
