:root{
  --bg:#0a0a0a;
  --bg2:#141414;
  --bg3:#1f1f1f;
  --bg4:#2a2a2a;
  --accent:#e50914;
  --accent2:#ff3d47;
  --gold:#f5a623;
  --green:#46d369;
  --blue:#0071eb;
  --text:#ffffff;
  --text2:#b3b3b3;
  --text3:#6d6d6d;
  --border:rgba(255,255,255,0.08);
  --border2:rgba(229,9,20,0.3);
  --font:'Outfit',sans-serif;
  --font-mono:'DM Mono',monospace;
  --nav-h:60px;
  --sidebar-w:220px;
  --ch-panel-w:240px;
}
*{box-sizing:border-box;margin:0;padding:0}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:var(--text3)}
body{font-family:var(--font);background:var(--bg);color:var(--text);height:100vh;display:flex;flex-direction:column;overflow:hidden}

/* ── TOPBAR ── */
.topbar{
  height:var(--nav-h);display:flex;align-items:center;
  padding:0 24px;gap:0;flex-shrink:0;
  background:linear-gradient(180deg,rgba(0,0,0,.95) 0%,rgba(0,0,0,.7) 100%);
  border-bottom:1px solid rgba(255,255,255,.05);
  position:relative;z-index:50;
}
.logo{
  font-size:22px;font-weight:900;letter-spacing:-1px;
  color:var(--accent);text-transform:uppercase;
  margin-right:28px;flex-shrink:0;display:flex;align-items:center;gap:8px;
}
.logo-icon{
  width:32px;height:32px;background:var(--accent);border-radius:4px;
  display:flex;align-items:center;justify-content:center;
}
.logo-icon svg{width:18px;height:18px}
.nav{display:flex;gap:2px;flex:1}
.nav-btn{
  height:var(--nav-h);padding:0 14px;
  border:none;background:transparent;
  color:var(--text2);font-family:var(--font);font-size:13px;font-weight:500;
  cursor:pointer;transition:all .15s;position:relative;white-space:nowrap;
  display:flex;align-items:center;gap:6px;
}
.nav-btn svg{width:14px;height:14px;opacity:.6;transition:all .15s}
.nav-btn:hover{color:var(--text)}
.nav-btn:hover svg{opacity:1}
.nav-btn.active{color:var(--text);font-weight:600}
.nav-btn.active::after{
  content:'';position:absolute;bottom:0;left:14px;right:14px;
  height:2px;background:var(--accent);border-radius:2px 2px 0 0;
}
.topbar-right{display:flex;align-items:center;gap:10px;margin-left:auto}
.status-pill{
  display:flex;align-items:center;gap:7px;
  padding:5px 12px;border-radius:4px;
  background:rgba(255,255,255,.05);border:1px solid var(--border);
  font-size:11px;font-weight:500;color:var(--text2);font-family:var(--font-mono);
}
.dot{width:6px;height:6px;border-radius:50%;background:var(--text3);flex-shrink:0}
.dot.live{background:var(--green);box-shadow:0 0 8px var(--green);animation:pulse 2s infinite}
.dot.loading{background:var(--gold);animation:pulse .6s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.proxy-badge{
  display:none;padding:4px 10px;border-radius:4px;
  background:rgba(0,113,235,.2);border:1px solid rgba(0,113,235,.4);
  color:#5ba3ff;font-size:10px;font-weight:700;letter-spacing:.5px;
  font-family:var(--font-mono);
}
.reload-btn{
  display:none;padding:5px 12px;border-radius:4px;
  background:rgba(229,9,20,.15);border:1px solid var(--border2);
  color:var(--accent2);font-size:11px;font-weight:600;cursor:pointer;
  font-family:var(--font);transition:all .15s;
}
.reload-btn:hover{background:rgba(229,9,20,.25)}

/* ── LAYOUT ── */
.main{display:flex;flex:1;overflow:hidden}
.page{display:none;flex:1;overflow:hidden}
.page.active{display:flex}

/* ── SIDEBAR ── */
.sidebar{
  width:var(--sidebar-w);flex-shrink:0;
  background:var(--bg2);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;overflow:hidden;
}

/* Filme em reprodução: player ocupa tela toda */
#page-live.vod-movie .sidebar,
#page-live.vod-movie .ch-panel { display:none }
.sb-head{padding:12px;border-bottom:1px solid var(--border);flex-shrink:0}
.sb-search{
  display:flex;align-items:center;gap:8px;
  background:var(--bg3);border:1px solid var(--border);
  border-radius:6px;padding:7px 10px;transition:border .15s;
}
.sb-search:focus-within{border-color:rgba(229,9,20,.4)}
.sb-search svg{width:12px;height:12px;color:var(--text3);flex-shrink:0}
.sb-search input{
  background:none;border:none;outline:none;
  color:var(--text);font-size:12px;width:100%;font-family:var(--font);
}
.sb-search input::placeholder{color:var(--text3)}
.cat-scroller{flex:1;overflow-y:auto;padding:8px 6px}
.cat-section{font-size:9px;font-weight:700;color:var(--text3);
  text-transform:uppercase;letter-spacing:1.5px;padding:10px 6px 5px;
  display:flex;align-items:center;justify-content:space-between}
.cat-section-action{font-size:9px;color:var(--accent);cursor:pointer;
  text-transform:none;letter-spacing:0;font-weight:600}
.cat-item{
  display:flex;align-items:center;gap:8px;
  padding:6px 8px;border-radius:5px;cursor:pointer;
  font-size:12px;font-weight:400;color:var(--text2);
  transition:all .1s;margin-bottom:1px;
}
.cat-item:hover{background:var(--bg3);color:var(--text)}
.cat-item.active{background:rgba(229,9,20,.12);color:var(--text);font-weight:600}
.cat-item.active .cat-ico{background:rgba(229,9,20,.2)}
.cat-ico{
  width:20px;height:20px;border-radius:4px;
  background:var(--bg4);display:flex;align-items:center;
  justify-content:center;font-size:11px;flex-shrink:0;
}
.cat-n{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cat-cnt{
  font-size:10px;color:var(--text3);
  background:var(--bg4);padding:1px 5px;border-radius:3px;
  font-family:var(--font-mono);flex-shrink:0;
}
.cat-edit-btn{
  font-size:12px;color:var(--text3);padding:0 2px;cursor:pointer;
  opacity:0;transition:opacity .1s;line-height:1;
}
.cat-item:hover .cat-edit-btn{opacity:1}

/* ── CHANNEL LIST ── */
.ch-panel{
  width:var(--ch-panel-w);flex-shrink:0;
  background:var(--bg);border-right:1px solid var(--border);
  display:flex;flex-direction:column;overflow:hidden;
}
.ch-head{
  padding:10px 12px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:8px;flex-shrink:0;
}
.ch-head-title{font-size:13px;font-weight:700;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ch-head-count{
  font-size:10px;color:var(--text3);
  background:var(--bg3);padding:2px 7px;border-radius:3px;
  font-family:var(--font-mono);
}
.ch-search-wrap{
  display:flex;align-items:center;gap:6px;
  padding:7px 12px;border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.ch-search-wrap svg{width:13px;height:13px;color:var(--text3);flex-shrink:0}
.ch-search-wrap input{
  flex:1;background:transparent;border:none;outline:none;
  font-size:12px;color:var(--text);font-family:var(--font);
}
.ch-search-wrap input::placeholder{color:var(--text3)}
.ch-scroller{flex:1;overflow-y:auto}
.ch-item{
  display:flex;align-items:center;gap:9px;
  padding:8px 12px;cursor:pointer;
  border-bottom:1px solid var(--border);
  transition:background .1s;position:relative;
}
.ch-item:hover{background:var(--bg2)}
.ch-item.active{background:rgba(229,9,20,.08)}
.ch-item.active::before{
  content:'';position:absolute;left:0;top:0;bottom:0;
  width:2px;background:var(--accent);
}
.ch-logo{
  width:36px;height:24px;border-radius:3px;
  background:var(--bg3);display:flex;align-items:center;
  justify-content:center;font-size:14px;flex-shrink:0;
  overflow:hidden;border:1px solid var(--border);
  position:relative;
}
.ch-logo::before{
  content:'📺';
  position:absolute;
  font-size:14px;
  opacity:.6;
}
.ch-logo img{
  width:100%;height:100%;object-fit:contain;
  position:relative;z-index:1;background:var(--bg3);
}
.ch-meta{flex:1;min-width:0}
.ch-name{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ch-grp{font-size:10px;color:var(--text3);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.live-pill{
  font-size:9px;font-weight:800;padding:2px 5px;border-radius:2px;
  background:var(--accent);color:white;flex-shrink:0;letter-spacing:.5px;
}

/* ── PLAYER ── */
.player-zone{flex:1;display:flex;flex-direction:column;background:#000;overflow:hidden}
.vid-wrap{
  flex:1;position:relative;background:#000;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.vid-wrap.hide-cursor{ cursor:none }
#vid{width:100%;height:100%;object-fit:contain;display:none}

/* Placeholder */
.vid-placeholder{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  pointer-events:none;
}
.vid-ph-logo{font-size:48px;margin-bottom:12px;opacity:.15}
.vid-ph-title{font-size:28px;font-weight:900;color:var(--accent);opacity:.4;letter-spacing:-1px}
.vid-ph-sub{font-size:12px;color:var(--text3);margin-top:6px;opacity:.6}

/* Erro */
.vid-error{
  position:absolute;inset:0;display:none;flex-direction:column;
  align-items:center;justify-content:center;
  background:rgba(10,10,10,.95);gap:8px;pointer-events:auto;z-index:10;
}
.vid-error.show{display:flex}
.vid-error-icon{font-size:32px;margin-bottom:4px}
.vid-error-msg{font-size:14px;font-weight:600;color:var(--text);text-align:center;max-width:320px;line-height:1.5}
.vid-error-tip{font-size:11px;color:var(--text3);text-align:center;max-width:320px;line-height:1.6;margin-top:2px}
.error-btns{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap;justify-content:center}
.err-btn{padding:8px 18px;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font);border:none;transition:all .15s}
.err-btn.primary{background:var(--accent);color:white}
.err-btn.primary:hover{background:var(--accent2)}

/* ── CUSTOM CONTROLS ── */
.ctrls{
  position:absolute;inset:0;display:flex;flex-direction:column;
  justify-content:flex-end;pointer-events:none;
  transition:opacity .3s ease;z-index:20;
}
.ctrls.hidden{ opacity:0 }
.ctrls.hidden *{ pointer-events:none !important }
.ctrls:not(.hidden) *{ pointer-events:auto }

.ctrls-grad{
  position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(to top,
    rgba(0,0,0,.85) 0%,
    rgba(0,0,0,.4)  30%,
    transparent     60%);
}

/* Info (nome + sub) */
.ctrls-info{
  position:relative;padding:0 16px 6px;
}
.np-title{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text);text-shadow:0 1px 4px rgba(0,0,0,.8)}
.np-sub{font-size:10px;color:rgba(255,255,255,.55);margin-top:1px;font-family:var(--font-mono)}

/* Progress bar */
.ctrls-progress{
  position:relative;padding:6px 16px 2px;cursor:pointer;
}
.prog-track{
  height:3px;background:rgba(255,255,255,.18);border-radius:2px;
  position:relative;transition:height .15s;
}
.ctrls-progress:hover .prog-track{ height:5px }
.prog-buf{position:absolute;inset:0;background:rgba(255,255,255,.25);border-radius:2px;width:0}
.prog-fill{position:absolute;inset:0;background:var(--accent);border-radius:2px;width:0;transition:width .1s linear}
.prog-thumb{
  position:absolute;top:50%;right:auto;transform:translate(-50%,-50%);
  width:13px;height:13px;border-radius:50%;background:#fff;
  opacity:0;transition:opacity .15s;left:0;pointer-events:none;
}
.ctrls-progress:hover .prog-thumb{ opacity:1 }
.prog-tooltip{
  position:absolute;bottom:calc(100% + 6px);
  background:rgba(0,0,0,.85);color:#fff;font-size:11px;font-weight:600;
  padding:3px 7px;border-radius:4px;pointer-events:none;
  display:none;transform:translateX(-50%);white-space:nowrap;font-family:var(--font-mono);
}

/* Botões row */
.ctrls-row{
  position:relative;display:flex;align-items:center;
  justify-content:space-between;padding:4px 10px 10px;gap:4px;
}
.ctrls-left,.ctrls-right{display:flex;align-items:center;gap:2px}

.ctrl-btn{
  display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:6px;
  background:transparent;border:none;
  color:rgba(255,255,255,.85);cursor:pointer;
  transition:background .12s,color .12s;flex-shrink:0;
}
.ctrl-btn:hover{background:rgba(255,255,255,.12);color:#fff}
.ctrl-btn svg{width:16px;height:16px;display:block}

/* Volume */
.ctrl-vol-wrap{display:flex;align-items:center;gap:0}
.ctrl-vol-slider{
  width:0;overflow:hidden;transition:width .2s ease;display:flex;align-items:center;
}
.ctrl-vol-wrap:hover .ctrl-vol-slider,
.ctrl-vol-wrap:focus-within .ctrl-vol-slider{ width:70px }
.ctrl-vol-slider input[type=range]{
  -webkit-appearance:none;width:62px;height:3px;margin:0 4px;
  background:rgba(255,255,255,.3);border-radius:2px;outline:none;cursor:pointer;
}
.ctrl-vol-slider input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:12px;height:12px;
  border-radius:50%;background:#fff;cursor:pointer;
}

/* Tempo */
.ctrl-time{
  font-size:11px;color:rgba(255,255,255,.7);font-family:var(--font-mono);
  padding:0 6px;white-space:nowrap;
}

/* Quality btn (dentro do player) */
.ctrl-quality-wrap{ position:relative }
.ctrl-quality-btn{
  width:auto;padding:0 10px;gap:5px;font-size:11px;font-weight:600;
  font-family:var(--font);color:rgba(255,255,255,.85);
}
.ctrl-quality-btn svg{width:13px;height:13px}

/* ── QUALITY MENU ── */
.quality-menu{
  position:absolute;bottom:calc(100% + 8px);left:0;z-index:40;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:8px;padding:6px;min-width:130px;
  box-shadow:0 -4px 24px rgba(0,0,0,.7);
  display:none;flex-direction:column;gap:2px;
  animation:qm-in .12s ease;
}
.quality-menu.open{display:flex}
@keyframes qm-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.quality-menu-title{
  font-size:10px;font-weight:700;color:var(--text3);
  text-transform:uppercase;letter-spacing:.08em;
  padding:2px 8px 6px;border-bottom:1px solid var(--border);margin-bottom:2px;
}
.quality-opt{
  padding:7px 12px;border-radius:5px;font-size:12px;font-weight:500;
  color:var(--text2);cursor:pointer;transition:background .1s,color .1s;
  display:flex;align-items:center;gap:8px;
}
.quality-opt:hover{background:var(--bg3);color:var(--text)}
.quality-opt.active{color:var(--accent);font-weight:700}
.quality-opt.active::before{content:'✓';font-size:10px;width:10px}
.quality-opt:not(.active)::before{content:'';width:10px;display:inline-block}
.quality-opt.locked{opacity:.45;cursor:default;pointer-events:none}


.err-btn.sec{background:var(--bg3);color:var(--text2);border:1px solid var(--border)}
.err-btn.sec:hover{background:var(--bg4);color:var(--text)}
.err-btn.vlc{background:rgba(245,166,35,.15);color:var(--gold);border:1px solid rgba(245,166,35,.3);display:none}
.err-btn.vlc:hover{background:rgba(245,166,35,.25)}

/* ── VOD LAYOUT ── */
.vod-layout{flex:1;display:flex;overflow:hidden}
.vod-content{flex:1;overflow-y:auto;background:var(--bg)}
.vod-header{
  padding:20px 20px 14px;
  background:linear-gradient(180deg,var(--bg2) 0%,var(--bg) 100%);
  display:flex;align-items:center;gap:12px;flex-shrink:0;
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:10;
}
.vod-search{
  background:var(--bg3);border:1px solid var(--border);
  border-radius:6px;padding:8px 14px 8px 36px;color:var(--text);
  font-size:12px;outline:none;width:260px;font-family:var(--font);
  transition:border .15s;position:relative;
}
.vod-search:focus{border-color:rgba(229,9,20,.4)}
.vod-search::placeholder{color:var(--text3)}
.search-icon-wrap{position:relative;flex-shrink:0}
.search-icon-wrap input{padding-left:34px}
.search-icon-abs{
  position:absolute;left:11px;top:50%;transform:translateY(-50%);
  color:var(--text3);pointer-events:none;
}
.vod-count{
  margin-left:auto;font-size:11px;color:var(--text3);
  font-family:var(--font-mono);
}
.sort-select{
  background:var(--bg3);border:1px solid var(--border);
  color:var(--text2);font-size:11px;padding:6px 10px;
  border-radius:5px;outline:none;font-family:var(--font);cursor:pointer;
}
.sort-select:focus{border-color:rgba(229,9,20,.4)}

/* ── VOD GRID ── */
.vod-grid-wrap{padding:16px 20px 20px}
.vod-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
  gap:12px;
}
.vod-card{
  background:var(--bg2);border-radius:6px;overflow:hidden;
  cursor:pointer;border:1px solid transparent;
  transition:all .2s;position:relative;
}
.vod-card:hover{
  border-color:rgba(229,9,20,.5);
  transform:scale(1.04);
  box-shadow:0 10px 30px rgba(0,0,0,.6),0 0 0 1px rgba(229,9,20,.3);
  z-index:2;
}
.vod-card:hover .vod-overlay{opacity:1}
.vod-thumb{
  width:100%;aspect-ratio:2/3;
  background:var(--bg3);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;position:relative;
}
.vod-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.vod-no-img{
  position:absolute;inset:0;display:flex;align-items:center;
  justify-content:center;background:var(--bg3);
}
.vod-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.9) 0%, rgba(0,0,0,.2) 60%, transparent 100%);
  display:flex;align-items:flex-end;justify-content:center;
  opacity:0;transition:opacity .2s;padding-bottom:12px;
}
.vod-play-btn{
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.95);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 10px rgba(0,0,0,.5);
}
.vod-play-btn svg{width:16px;height:16px;color:#000;margin-left:2px}
.vod-badge{
  position:absolute;top:6px;left:6px;
  background:rgba(0,0,0,.7);backdrop-filter:blur(4px);
  color:var(--text2);font-size:9px;font-weight:600;
  padding:2px 6px;border-radius:3px;letter-spacing:.3px;
  white-space:nowrap;overflow:hidden;max-width:80%;text-overflow:ellipsis;
}
.vod-body{padding:8px 8px 10px}
.vod-name{
  font-size:11px;font-weight:600;line-height:1.35;color:var(--text);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.load-more-wrap{padding:20px;text-align:center;grid-column:1/-1}
.load-more-btn{
  padding:10px 32px;border-radius:4px;
  background:var(--bg3);border:1px solid var(--border);
  color:var(--text2);font-size:12px;font-weight:600;cursor:pointer;
  font-family:var(--font);transition:all .15s;
}
.load-more-btn:hover{background:var(--bg4);color:var(--text);border-color:rgba(255,255,255,.2)}

/* ── ADD PLAYLIST ── */
.add-page{flex:1;overflow-y:auto;padding:28px 24px;display:flex;flex-direction:column;align-items:center}
.add-card{
  width:100%;max-width:520px;background:var(--bg2);border-radius:8px;
  border:1px solid var(--border);padding:24px;margin-bottom:16px;
}
.add-card h2{font-size:20px;font-weight:800;margin-bottom:4px}
.add-card>p{color:var(--text2);font-size:13px;line-height:1.65;margin-bottom:20px}
.segment{
  display:flex;background:var(--bg3);border-radius:6px;
  padding:3px;gap:2px;margin-bottom:18px;
}
.seg-btn{
  flex:1;padding:7px 10px;border-radius:4px;border:none;
  background:transparent;color:var(--text2);font-size:12px;
  cursor:pointer;font-family:var(--font);font-weight:600;transition:all .15s;
}
.seg-btn:hover{color:var(--text)}
.seg-btn.active{background:var(--bg4);color:var(--text);box-shadow:0 2px 8px rgba(0,0,0,.3)}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}
.form-group input{
  width:100%;background:var(--bg3);border:1px solid var(--border);
  border-radius:6px;padding:10px 12px;color:var(--text);font-size:14px;
  outline:none;font-family:var(--font);transition:border .15s;
}
.form-group input:focus{border-color:rgba(229,9,20,.4)}
.form-group input::placeholder{color:var(--text3)}
.btn-primary{
  width:100%;padding:12px;border-radius:6px;border:none;
  background:var(--accent);color:white;font-size:14px;font-weight:700;
  cursor:pointer;font-family:var(--font);transition:all .15s;margin-top:8px;
}
.btn-primary:hover{background:var(--accent2);transform:translateY(-1px);box-shadow:0 4px 12px rgba(229,9,20,.3)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* ── SAVED LIST ── */
.saved-list{margin-top:24px;width:100%;max-width:520px;align-self:center}
.saved-item{
  display:flex;align-items:center;gap:12px;padding:12px;
  background:var(--bg3);border-radius:8px;margin-bottom:10px;
  border:1px solid var(--border);transition:all .15s;
}
.saved-item:hover{border-color:rgba(255,255,255,.15)}
.saved-ico{width:40px;height:40px;background:var(--bg4);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:20px}
.saved-info{flex:1;min-width:0}
.saved-name{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.saved-url{font-size:11px;color:var(--text3);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.saved-stats{font-size:10px;color:var(--text2);margin-top:4px;display:flex;gap:10px}
.btn-load{padding:6px 14px;border-radius:4px;border:none;background:var(--accent);color:white;font-size:12px;font-weight:600;cursor:pointer}
.btn-del{padding:6px 10px;border-radius:4px;border:none;background:var(--bg4);color:var(--text3);font-size:12px;cursor:pointer}
.btn-del:hover{color:var(--accent)}

/* ── CONFIG PAGE ── */
.settings-page{flex:1;overflow-y:auto;padding:28px 24px}
.set-card{max-width:600px;background:var(--bg2);border-radius:8px;border:1px solid var(--border);margin-bottom:20px;overflow:hidden}
.set-head{padding:16px 20px;background:rgba(255,255,255,.02);border-bottom:1px solid var(--border);font-size:14px;font-weight:700}
.set-row{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}
.set-row:last-child{border-bottom:none}
.set-info{flex:1;padding-right:20px}
.set-title{font-size:13px;font-weight:600}
.set-desc{font-size:11px;color:var(--text3);margin-top:3px;line-height:1.5}
.switch{width:40px;height:22px;background:var(--bg4);border-radius:20px;position:relative;cursor:pointer;transition:all .2s}
.switch::after{content:'';position:absolute;left:3px;top:3px;width:16px;height:16px;background:var(--text3);border-radius:50%;transition:all .2s}
.switch.on{background:var(--green)}
.switch.on::after{left:21px;background:white}

/* ── MODALS ── */
.modal-bg{
  position:fixed;inset:0;background:rgba(0,0,0,.85);
  display:none;align-items:center;justify-content:center;z-index:500;
  backdrop-filter:blur(4px);padding:20px;
}
.modal-bg.show{display:flex}
.modal{
  background:var(--bg2);width:100%;max-width:480px;
  border-radius:12px;border:1px solid rgba(255,255,255,.1);
  display:flex;flex-direction:column;max-height:85vh;
  box-shadow:0 20px 50px rgba(0,0,0,.8);
}
.modal-head{padding:18px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-title{font-size:16px;font-weight:800}
.modal-body{flex:1;overflow-y:auto;padding:12px}
.cat-row{
  display:flex;align-items:center;gap:12px;padding:10px 12px;
  border-radius:8px;transition:all .1s;border:1px solid transparent;
}
.cat-row:hover{background:var(--bg3)}
.cat-row.hidden-row{opacity:.4}
.drag-handle{cursor:grab;color:var(--text3);font-size:14px;padding:4px}
.cat-row-ico{width:32px;height:32px;background:var(--bg4);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:16px}
.cat-row-name{flex:1;min-width:0}
.cat-row-orig{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cat-row-label{font-size:10px;color:var(--text3);margin-top:1px}
.cat-row-count{font-size:11px;font-family:var(--font-mono);color:var(--text3);background:var(--bg4);padding:2px 6px;border-radius:4px}
.icon-btn{
  width:32px;height:32px;border-radius:6px;border:1px solid var(--border);
  background:transparent;color:var(--text2);cursor:pointer;display:flex;
  align-items:center;justify-content:center;transition:all .1s;
}
.icon-btn:hover{background:var(--bg2);color:var(--text)}
.icon-btn.active{background:rgba(229,9,20,.1);border-color:rgba(229,9,20,.3);color:var(--accent)}
.modal-foot{padding:12px 20px;border-top:1px solid var(--border);display:flex;gap:8px;flex-shrink:0}
.modal-btn{flex:1;padding:9px;border-radius:5px;border:none;font-family:var(--font);font-size:12px;font-weight:600;cursor:pointer}
.modal-btn.primary{background:var(--accent);color:white}
.modal-btn.primary:hover{background:var(--accent2)}
.modal-btn.sec{background:var(--bg3);color:var(--text2);border:1px solid var(--border)}
.modal-btn.sec:hover{background:var(--bg4);color:var(--text)}

/* ── RENAME POPUP ── */
.rename-popup{
  position:fixed;background:var(--bg2);border:1px solid rgba(255,255,255,.15);
  border-radius:8px;padding:12px;z-index:600;
  box-shadow:0 8px 32px rgba(0,0,0,.6);width:220px;display:none;pointer-events:none;
}
.rename-popup.show{display:block;pointer-events:auto}
.rename-popup input{
  width:100%;background:var(--bg3);border:1px solid var(--border);
  border-radius:5px;padding:7px 10px;color:var(--text);font-size:13px;
  outline:none;font-family:var(--font);margin-bottom:8px;
}
.rename-popup input:focus{border-color:rgba(229,9,20,.4)}
.rename-popup-row{display:flex;gap:6px}
.rp-btn{flex:1;padding:6px;border-radius:4px;border:none;font-size:12px;cursor:pointer;font-family:var(--font);font-weight:600}
.rp-ok{background:var(--accent);color:white}
.rp-cancel{background:var(--bg3);color:var(--text2);border:1px solid var(--border)}

/* ── TOAST ── */
.toast{
  position:fixed;bottom:20px;right:20px;
  background:var(--bg3);border:1px solid rgba(255,255,255,.1);
  border-radius:6px;padding:10px 16px;font-size:12px;font-weight:500;
  z-index:9999;transform:translateY(10px);opacity:0;
  transition:all .22s;pointer-events:none;max-width:280px;
  box-shadow:0 4px 24px rgba(0,0,0,.5);
}
.toast.show{transform:translateY(0);opacity:1}

/* ── DRAG OVERLAY ── */
.drag-ov{
  display:none;position:fixed;inset:0;
  background:rgba(229,9,20,.08);
  border:2px dashed rgba(229,9,20,.5);z-index:200;
  align-items:center;justify-content:center;
  font-size:18px;font-weight:700;color:var(--accent);
  pointer-events:none;
}
.drag-ov.show{display:flex}

@keyframes spin{to{transform:rotate(360deg)}}

/* ── HOME PAGE ── */
.home-stat{
  flex:1;padding:18px 20px;cursor:pointer;
  border-right:1px solid var(--border);text-align:center;
  transition:background .15s;
}
.home-stat:last-child{border-right:none}
.home-stat:hover{background:var(--bg3)}
.home-stat-num{font-size:26px;font-weight:800;color:var(--text);font-family:var(--font)}
.home-stat-lbl{font-size:10px;color:var(--text3);margin-top:3px;font-weight:600;text-transform:uppercase;letter-spacing:.8px}
.home-section{padding:24px 24px 16px}
.home-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.home-section-title{font-size:16px;font-weight:800;color:var(--text);letter-spacing:-.3px}
.home-section-action{font-size:11px;color:var(--accent);cursor:pointer;font-weight:600;transition:color .15s}
.home-section-action:hover{color:var(--accent2)}

/* Live cards row */
.live-cards-row{display:flex;gap:10px;overflow-x:auto;padding-bottom:8px}
.live-cards-row::-webkit-scrollbar{height:3px}
.live-cards-row::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:2px}
.live-card{
  flex-shrink:0;width:130px;background:var(--bg2);border-radius:6px;
  overflow:hidden;cursor:pointer;border:1px solid var(--border);
  transition:all .2s;
}
.live-card:hover{border-color:rgba(229,9,20,.4);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.5)}
.live-card-logo{
  width:100%;height:75px;background:var(--bg3);
  display:flex;align-items:center;justify-content:center;
  font-size:28px;overflow:hidden;
}
.live-card-logo img{width:100%;height:100%;object-fit:contain;padding:8px}
.live-card-name{font-size:11px;font-weight:600;padding:7px 8px 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.live-card-pill{
  font-size:9px;font-weight:800;color:var(--accent);
  padding:3px 8px 7px;letter-spacing:.5px;
}

/* Rank row - Netflix style */
.rank-row{display:flex;gap:0;overflow-x:auto;padding-bottom:52px;overflow-y:visible}
.rank-row::-webkit-scrollbar{height:3px}
.rank-row::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:2px}
.rank-card{
  flex-shrink:0;display:flex;align-items:flex-end;
  cursor:pointer;transition:transform .2s;
  position:relative;margin-right:14px;
}
.rank-card:last-child{margin-right:0}
.rank-card:hover{transform:scale(1.05);z-index:2}
.rank-card:hover .rank-overlay{opacity:1}
.rank-number{
  font-size:100px;font-weight:900;color:var(--bg3);
  line-height:1;margin-right:-12px;z-index:1;
  -webkit-text-stroke:2px var(--bg4);
  font-family:var(--font);flex-shrink:0;
  text-shadow:-2px 0 var(--bg4), 0 2px var(--bg4);
  min-width:80px;text-align:right;
}
.rank-thumb{
  width:100px;height:150px;background:var(--bg3);
  border-radius:5px;overflow:hidden;flex-shrink:0;
  border:1px solid var(--border);position:relative;
  box-shadow:4px 0 20px rgba(0,0,0,.6);
}
.rank-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.rank-overlay{
  position:absolute;inset:0;
  background:rgba(0,0,0,.5);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .2s;border-radius:5px;
}
.rank-play-btn{
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.9);
  display:flex;align-items:center;justify-content:center;
}
.rank-play-btn svg{width:14px;height:14px;color:#000;margin-left:2px}
.rank-info{
  position:absolute;bottom:-40px;left:80px;
  width:100px;pointer-events:none;
}
.rank-name{font-size:10px;font-weight:700;color:var(--text);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.rank-meta{font-size:9px;color:var(--text3);margin-top:2px}

/* ── SERIES OVERLAY ── */
.series-ov-bg{
  display:none;position:fixed;inset:0;z-index:200;
  background:rgba(0,0,0,.85);backdrop-filter:blur(6px);
  align-items:center;justify-content:center;
}
.series-ov-bg.open{display:flex;animation:sovFadeIn .2s ease}
@keyframes sovFadeIn{from{opacity:0}to{opacity:1}}
.series-ov-panel{
  position:relative;width:min(860px,96vw);max-height:90vh;
  background:var(--bg2);border-radius:12px;overflow:hidden;
  display:flex;flex-direction:column;
  box-shadow:0 32px 80px rgba(0,0,0,.8);
  animation:sovSlideUp .25s ease;
}
@keyframes sovSlideUp{from{transform:translateY(28px);opacity:0}to{transform:translateY(0);opacity:1}}
.series-ov-hero{
  position:relative;min-height:220px;flex-shrink:0;overflow:hidden;
}
.series-ov-backdrop{
  position:absolute;inset:0;
  background-size:cover;background-position:center top;
  filter:blur(3px) brightness(.3);transform:scale(1.06);
}
.series-ov-hero::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 30%,var(--bg2) 100%);
}
.series-ov-hero-content{
  position:relative;z-index:2;
  display:flex;gap:20px;align-items:flex-end;
  padding:24px 28px 20px;
}
.series-ov-poster{
  width:100px;height:148px;flex-shrink:0;border-radius:6px;
  overflow:hidden;background:var(--bg3);
  box-shadow:0 8px 24px rgba(0,0,0,.6);
}
.series-ov-poster img{width:100%;height:100%;object-fit:cover;display:block}
.sov-poster-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:36px}
.series-ov-info{display:flex;flex-direction:column;gap:8px;padding-bottom:4px}
.series-ov-title{font-size:24px;font-weight:800;line-height:1.2;color:var(--text);letter-spacing:-.3px}
.series-ov-meta{font-size:12px;color:var(--text3)}
.series-ov-play-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 22px;border-radius:5px;background:var(--accent);
  color:white;border:none;font-size:13px;font-weight:700;
  cursor:pointer;font-family:var(--font);transition:background .15s;width:fit-content;
}
.series-ov-play-btn:hover{background:var(--accent2)}
.series-ov-close{
  position:absolute;top:14px;right:14px;z-index:10;
  width:32px;height:32px;border-radius:50%;
  background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.15);
  color:var(--text2);font-size:14px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .15s;
}
.series-ov-close:hover{background:rgba(255,255,255,.15);color:var(--text)}
.series-ov-body{display:flex;flex-direction:column;overflow:hidden;flex:1}
.series-ov-seasons{
  display:flex;gap:6px;padding:14px 28px 10px;
  border-bottom:1px solid var(--border);overflow-x:auto;flex-shrink:0;
}
.series-ov-seasons::-webkit-scrollbar{height:3px}
.sov-season-btn{
  padding:6px 16px;border-radius:20px;background:var(--bg3);
  border:1px solid var(--border);color:var(--text2);
  font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;
  transition:all .15s;font-family:var(--font);
}
.sov-season-btn:hover{background:var(--bg4);color:var(--text)}
.sov-season-btn.active{background:var(--accent);border-color:var(--accent);color:white}
.series-ov-episodes{overflow-y:auto;flex:1;padding:12px 28px 20px;display:grid;gap:6px}
.sov-ep{
  display:flex;align-items:center;gap:14px;padding:10px 12px;
  border-radius:8px;background:var(--bg3);cursor:pointer;
  transition:background .15s;border:1px solid transparent;
}
.sov-ep:hover{background:var(--bg4);border-color:var(--border)}
.sov-ep.playing{border-color:var(--accent);background:rgba(229,9,20,.08)}
.sov-ep-num{font-size:13px;font-weight:700;color:var(--text3);min-width:28px;text-align:center;flex-shrink:0;font-family:var(--font-mono)}
.sov-ep-thumb{width:72px;height:44px;flex-shrink:0;border-radius:4px;overflow:hidden;background:var(--bg4);display:flex;align-items:center;justify-content:center;font-size:18px}
.sov-ep-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.sov-ep-info{flex:1;min-width:0}
.sov-ep-title{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sov-ep-sub{font-size:11px;color:var(--text3);margin-top:2px}
.sov-ep-play{width:32px;height:32px;border-radius:50%;flex-shrink:0;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;transition:background .15s}
.sov-ep:hover .sov-ep-play{background:var(--accent)}
.sov-ep-play svg{width:12px;height:12px;margin-left:2px}
.sov-ep.playing .sov-ep-num{color:var(--accent)}

/* Episódios já assistidos: mais apagados */
.sov-ep.watched{opacity:.5}
.sov-ep.watched:hover{opacity:.8}
.sov-ep.watched .sov-ep-num{color:#4caf50;font-size:15px}
.sov-ep.watched .sov-ep-title{color:var(--text3)}

/* ── VOD SIDEBAR (episódios na sidebar ao vivo) ── */
.vod-sidebar-back{
  padding:10px 14px;font-size:12px;font-weight:600;
  color:var(--accent);cursor:pointer;
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:6px;
  transition:background .15s;
}
.vod-sidebar-back:hover{background:var(--bg3)}

/* ── EXPIRY BADGE ── */
.expiry-badge{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;
  background:rgba(255,255,255,.07);border:1px solid var(--border);
  color:var(--text2);white-space:nowrap;
}
.expiry-badge.ok{ border-color:var(--green);color:var(--green); }
.expiry-badge.warn{ border-color:var(--gold);color:var(--gold); }
.expiry-badge.expired{ border-color:var(--accent);color:var(--accent); }

/* ── HOME LOADING SCREEN ── */
#home-loading{ position:relative; }

.hl-spinner-wrap{
  position:relative;
  width:160px;height:160px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:36px;
}
.hl-ring{
  position:absolute;inset:0;border-radius:50%;
  border:3px solid rgba(229,9,20,.15);
  border-top-color:var(--accent);
  border-right-color:var(--accent);
  animation:hlSpin 1.2s cubic-bezier(.6,.2,.4,.8) infinite;
}
.hl-ring::before{
  content:'';position:absolute;inset:10px;border-radius:50%;
  border:2px solid rgba(229,9,20,.08);
  border-bottom-color:rgba(229,9,20,.4);
  animation:hlSpin 1.8s cubic-bezier(.6,.2,.4,.8) infinite reverse;
}
@keyframes hlSpin{ to{ transform:rotate(360deg); } }

.hl-logo{
  font-size:28px;font-weight:900;letter-spacing:-2px;
  color:var(--accent);font-family:var(--font);
  animation:hlPulse 1.2s ease-in-out infinite;
}
@keyframes hlPulse{ 0%,100%{opacity:1} 50%{opacity:.5} }

.hl-progress-wrap{
  display:flex;align-items:center;gap:12px;
  margin-bottom:28px;width:280px;max-width:90vw;
}
.hl-progress-bar{
  flex:1;height:3px;border-radius:2px;
  background:rgba(255,255,255,.08);overflow:hidden;
}
.hl-progress-fill{
  height:100%;background:var(--accent);border-radius:2px;
  width:0%;transition:width .4s ease;
}
.hl-progress-pct{
  font-size:12px;font-weight:700;color:var(--accent);
  min-width:36px;text-align:right;font-family:var(--font-mono);
}
.hl-msg{
  font-size:20px;font-weight:700;color:var(--text);
  margin-bottom:10px;line-height:1.3;
  animation:hlFadeSlide .5s ease;
}
.hl-submsg{
  font-size:13px;color:var(--text3);max-width:320px;line-height:1.6;
  animation:hlFadeSlide .5s ease;
}
@keyframes hlFadeSlide{ from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE / MEDIA QUERIES
   Breakpoints:
     ≤1024px  — tablet landscape
     ≤768px   — tablet portrait / large phone
     ≤480px   — mobile
   ══════════════════════════════════════════════════════════════ */

/* ── TABLET LANDSCAPE (≤1024px) ── */
@media (max-width: 1024px) {
  :root {
    --sidebar-w: 180px;
    --ch-panel-w: 200px;
  }

  .nav-btn { font-size: 12px; padding: 6px 10px; gap: 5px; }
  .topbar-right { gap: 6px; }
  .expiry-badge, .proxy-badge { font-size: 10px; padding: 2px 8px; }

  .vod-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 12px; }

  .series-ov-panel { width: min(720px, 96vw); }
  .series-ov-title { font-size: 20px; }

  /* Home responsiva */
  .home-stats { grid-template-columns: repeat(3, 1fr) !important; }
  .home-section { padding: 18px 18px 12px; }
  .live-card { min-width: 130px; max-width: 130px; }
  .rank-card { min-width: 110px; max-width: 110px; }
}

/* ── TABLET PORTRAIT (≤768px) ── */
@media (max-width: 768px) {
  :root {
    --sidebar-w: 0px;
    --ch-panel-w: 100%;
  }

  /* Topbar compacta */
  .topbar { padding: 0 12px; height: 52px; }
  .logo-text { font-size: 16px; }
  .nav { gap: 0; }
  .nav-btn { font-size: 11px; padding: 5px 8px; gap: 4px; }
  .nav-btn svg { display: none; }
  .expiry-badge { display: none; }
  .reload-btn { font-size: 11px; padding: 5px 10px; }

  /* Layout: esconde sidebar de categorias, ch-panel vira tela cheia ou overlay */
  #page-live .sidebar { display: none; }

  /* Player zone ocupa tudo */
  #page-live { flex-direction: column; }
  .ch-panel {
    width: 100% !important;
    max-height: 45vh;
    border-right: none;
    border-bottom: 1px solid var(--border);
    order: 2;
  }
  .player-zone { order: 1; min-height: 40vw; }
  .vid-controls { padding: 8px 12px; }

  /* VOD grids menores */
  .vod-grid { grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 10px; }
  .vod-grid-wrap { padding: 12px; }

  /* Series overlay mobile */
  .series-ov-panel { width: 100vw; max-height: 100vh; border-radius: 0; }
  .series-ov-hero { min-height: 160px; }
  .series-ov-hero-content { padding: 16px 16px 14px; gap: 14px; }
  .series-ov-poster { width: 72px; height: 108px; }
  .series-ov-title { font-size: 17px; }
  .series-ov-meta { font-size: 11px; }
  .series-ov-episodes { padding: 10px 16px 16px; }
  .series-ov-seasons { padding: 10px 16px 8px; }
  .sov-ep { padding: 8px 10px; gap: 10px; }
  .sov-ep-thumb { width: 56px; height: 36px; }

  /* Home loading */
  .hl-spinner-wrap { width: 120px; height: 120px; margin-bottom: 24px; }
  .hl-logo { font-size: 22px; }
  .hl-msg { font-size: 16px; }
  .hl-progress-wrap { width: 240px; }

  /* Playlist page */
  #page-add { padding: 16px; }
  .add-card { width: 100%; max-width: 100%; }

  /* Sidebar de séries/filmes no player mobile */
  .ch-scroller { max-height: 38vh; }
}

/* ── MOBILE (≤480px) ── */
@media (max-width: 480px) {
  .topbar { padding: 0 8px; height: 48px; }
  .logo-wrap { gap: 6px; }
  .logo-icon { width: 26px; height: 26px; font-size: 13px; }
  .logo-text { font-size: 14px; }
  .nav-btn { font-size: 10px; padding: 4px 6px; }

  /* Status pill compacto */
  .status-pill span { display: none; }
  .proxy-badge { display: none; }
  .reload-btn { font-size: 10px; padding: 4px 8px; }

  /* Player mais alto no mobile */
  .player-zone { min-height: 50vw; }
  .ch-panel { max-height: 40vh; }

  /* VOD grid 2 colunas fixas */
  .vod-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .vod-grid-wrap { padding: 10px; }
  .vod-name { font-size: 10px; }

  /* Home hero */
  .home-logo { font-size: 40px; }

  /* Overlay séries fullscreen */
  .series-ov-hero-content { flex-direction: column; align-items: flex-start; padding: 12px; }
  .series-ov-poster { width: 60px; height: 90px; }
  .series-ov-title { font-size: 15px; }
  .series-ov-close { top: 8px; right: 8px; }

  /* Ch items menores */
  .ch-item { padding: 6px 10px; gap: 8px; }
  .ch-logo { width: 30px; height: 20px; }
  .ch-name { font-size: 11px; }

  /* Loading screen mobile */
  .hl-spinner-wrap { width: 100px; height: 100px; margin-bottom: 20px; }
  .hl-logo { font-size: 18px; }
  .hl-msg { font-size: 14px; }
  .hl-submsg { font-size: 12px; }
  .hl-progress-wrap { width: 200px; }
}

/* ── LANDSCAPE PHONE (altura pequena) ── */
@media (max-height: 500px) and (orientation: landscape) {
  .series-ov-hero { min-height: 120px; }
  .series-ov-panel { max-height: 100vh; }
  .hl-spinner-wrap { width: 80px; height: 80px; margin-bottom: 12px; }
  .hl-msg { font-size: 13px; }
  .hl-submsg { display: none; }
}

/* ── PWA / STANDALONE ── */
@media (display-mode: standalone) {
  .topbar { padding-top: env(safe-area-inset-top, 0px); }
  body { padding-bottom: env(safe-area-inset-bottom, 0px); }
}

/* ── TV BOX / D-PAD NAVIGATION ── */
/* Foco só visível ao navegar por teclado/controle (não com mouse/touch) */
.ch-item:focus-visible, .vod-card:focus-visible, .rank-card:focus-visible,
.nav-btn:focus-visible, .continue-card:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
/* Remove qualquer outline padrão indesejado em foco por mouse/touch */
.ch-item:focus, .vod-card:focus, .rank-card:focus, .continue-card:focus {
  outline: none;
}

/* ── CONTINUE ASSISTINDO ── */
.continue-card {
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px;
  cursor: pointer;
  transition: background .15s, transform .15s;
  margin-top: 10px;
}
.continue-card:hover {
  background: var(--bg3, #2a2a2a);
  transform: scale(1.01);
}
.continue-card:focus-visible {
  outline: 2px solid var(--accent);
}
.continue-thumb {
  position: relative;
  width: 90px;
  min-width: 90px;
  height: 130px;
  border-radius: 7px;
  overflow: hidden;
  background: #111;
}
.continue-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.continue-no-img {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
}
.continue-progress-bar {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: rgba(255,255,255,.2);
}
.continue-progress-fill {
  height: 100%;
  background: var(--accent);
  border-radius: 2px;
}
.continue-play-icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: rgba(0,0,0,.6);
  color: white;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  opacity: 0;
  transition: opacity .2s;
}
.continue-card:hover .continue-play-icon,
.continue-card:focus .continue-play-icon { opacity: 1; }
.continue-info { flex: 1; min-width: 0; }
.continue-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 5px;
}
.continue-meta {
  font-size: 12px;
  color: var(--text2, #888);
  margin-bottom: 6px;
}
.continue-pct {
  font-size: 12px;
  color: var(--accent);
  font-weight: 600;
}

/* ── REFINAMENTOS MOBILE (sem alterar estrutura) ── */
@media (max-width: 768px) {
  /* Topbar: esconde "PROXY" badge e "Trial" badge para liberar espaço */
  .proxy-badge { display: none; }
  .expiry-badge.compact-mobile { display: none; }

  /* Status pill compacto */
  .status-pill { padding: 4px 8px; font-size: 11px; }

  /* Stats com divisores visuais sutis */
  #home-stats {
    background: linear-gradient(180deg, var(--bg2) 0%, var(--bg) 100%);
    padding: 4px 0;
  }
  .home-stat {
    flex: 1;
    padding: 14px 8px !important;
    position: relative;
    text-align: center;
    transition: background .15s;
  }
  .home-stat:not(:last-child)::after {
    content: '';
    position: absolute;
    right: 0;
    top: 25%;
    height: 50%;
    width: 1px;
    background: var(--border);
  }
  .home-stat:active { background: rgba(229,9,20,.05); }
  .home-stat-num { font-size: 22px !important; font-weight: 700 !important; }
  .home-stat-lbl { font-size: 10px !important; margin-top: 4px; letter-spacing: .5px; text-transform: uppercase; opacity: .7; }

  /* Seções da home: padding consistente, títulos mais limpos */
  .home-section { padding: 18px 14px 6px !important; }
  .home-section-head { margin-bottom: 12px !important; }
  .home-section-title { font-size: 16px !important; font-weight: 600 !important; }
  .home-section-action { font-size: 12px !important; opacity: .8; }

  /* Canais em destaque: cards mais compactos e ordenados */
  .live-card-row, #home-live {
    display: flex !important;
    gap: 10px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding-bottom: 6px;
    scrollbar-width: none;
  }
  #home-live::-webkit-scrollbar { display: none; }
  .live-card {
    min-width: 110px !important;
    flex: 0 0 110px !important;
    scroll-snap-align: start;
    padding: 12px 10px !important;
    border-radius: 10px !important;
  }
  .live-card-logo {
    height: 56px !important;
    margin-bottom: 8px;
  }
  .live-card-logo img { max-height: 48px; object-fit: contain; }
  .live-card-name {
    font-size: 12px !important;
    font-weight: 600 !important;
    line-height: 1.2;
    margin-bottom: 4px;
  }
  .live-card-pill {
    font-size: 9px !important;
    padding: 2px 6px !important;
    opacity: .8;
  }

  /* Top 10 cards: melhor scroll horizontal */
  #rank-movies, #rank-series {
    gap: 10px !important;
    padding-bottom: 6px;
    scrollbar-width: none;
  }
  #rank-movies::-webkit-scrollbar, #rank-series::-webkit-scrollbar { display: none; }
  .rank-card {
    min-width: 105px !important;
    flex: 0 0 105px !important;
  }

  /* Continue assistindo: card mais bonito no mobile */
  #home-continue-section {
    padding: 14px 14px 0 !important;
  }
  .continue-card {
    padding: 10px !important;
    gap: 12px !important;
    border-radius: 12px !important;
  }
  .continue-thumb {
    width: 75px !important;
    min-width: 75px !important;
    height: 108px !important;
  }
  .continue-title { font-size: 14px !important; }
  .continue-meta { font-size: 11px !important; }
  .continue-pct { font-size: 11px !important; }

  /* Tap feedback em tudo que é clicável */
  .ch-item, .vod-card, .rank-card, .live-card, .home-stat, .continue-card {
    -webkit-tap-highlight-color: transparent;
  }
  .ch-item:active, .vod-card:active, .rank-card:active, .live-card:active, .continue-card:active {
    opacity: .75;
    transition: opacity .1s;
  }
}

@media (max-width: 480px) {
  /* Stats ainda mais compactos */
  .home-stat { padding: 12px 6px !important; }
  .home-stat-num { font-size: 19px !important; }
  .home-stat-lbl { font-size: 9px !important; }

  /* Seções com padding menor */
  .home-section { padding: 14px 12px 4px !important; }
  .home-section-title { font-size: 14px !important; }

  /* Live cards ainda menores */
  .live-card { min-width: 95px !important; flex: 0 0 95px !important; padding: 10px 8px !important; }
  .live-card-logo { height: 48px !important; }
  .live-card-name { font-size: 11px !important; }

  /* Rank cards menores */
  .rank-card { min-width: 90px !important; flex: 0 0 90px !important; }
}

/* ── CORREÇÕES MOBILE ESPECÍFICAS ── */
@media (hover: none) and (pointer: coarse), (max-width: 768px) {
  /* Volume sempre visível em dispositivos touch (sem hover) */
  .ctrl-vol-slider {
    width: 70px !important;
    overflow: visible !important;
  }
  /* Slider de volume MAIOR e mais arrastável no touch */
  .ctrl-vol-slider input[type=range] {
    width: 70px;
    height: 24px; /* área tocável maior */
    background: transparent;
    padding: 10px 0; /* hit area generosa */
    margin: 0;
    box-sizing: content-box;
  }
  .ctrl-vol-slider input[type=range]::-webkit-slider-runnable-track {
    height: 3px;
    background: rgba(255,255,255,.3);
    border-radius: 2px;
  }
  .ctrl-vol-slider input[type=range]::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #fff;
    margin-top: -7px;
    border: none;
    box-shadow: 0 0 4px rgba(0,0,0,.4);
  }
  .ctrl-vol-slider input[type=range]::-moz-range-thumb {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #fff;
    border: none;
  }

  /* Botões dos controles MAIORES no touch (acessibilidade) */
  .ctrl-btn {
    min-width: 40px;
    min-height: 40px;
    padding: 8px !important;
  }
  .ctrl-btn svg {
    width: 22px;
    height: 22px;
  }

  /* Barra de progresso com área tocável maior */
  .ctrls-progress {
    padding: 12px 0;
    margin: -8px 0;
  }
  .prog-track {
    height: 4px;
  }
  .prog-thumb {
    width: 16px;
    height: 16px;
    opacity: 1; /* sempre visível no touch */
  }
}

/* Em mobile (≤768px), no fullscreen, garante que os controles fiquem acima de tudo */
@media (max-width: 768px) {
  .vid-wrap:fullscreen .ctrls,
  .vid-wrap:-webkit-full-screen .ctrls {
    z-index: 99999;
    pointer-events: auto !important;
  }
  .vid-wrap:fullscreen .ctrls.hidden,
  .vid-wrap:-webkit-full-screen .ctrls.hidden {
    opacity: 0;
  }
  .vid-wrap:fullscreen .ctrls:not(.hidden) *,
  .vid-wrap:-webkit-full-screen .ctrls:not(.hidden) * {
    pointer-events: auto !important;
  }

  /* No fullscreen, controles maiores e visíveis por mais tempo */
  .vid-wrap:fullscreen .ctrl-btn,
  .vid-wrap:-webkit-full-screen .ctrl-btn {
    min-width: 48px;
    min-height: 48px;
  }
  .vid-wrap:fullscreen .ctrl-btn svg,
  .vid-wrap:-webkit-full-screen .ctrl-btn svg {
    width: 26px;
    height: 26px;
  }
}

/* ── SEEK FEEDBACK (animação tipo YouTube ao avançar/voltar) ── */
.seek-feedback {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 35%;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  opacity: 0;
  z-index: 50;
}
.seek-feedback.seek-left { left: 0; }
.seek-feedback.seek-right { right: 0; }
.seek-feedback.show {
  animation: seekPulse .6s ease;
}
.seek-fb-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  background: rgba(0,0,0,.55);
  color: #fff;
  border-radius: 50%;
  width: 90px;
  height: 90px;
  justify-content: center;
  font-size: 26px;
}
.seek-fb-inner span {
  font-size: 13px;
  font-weight: 600;
}
@keyframes seekPulse {
  0% { opacity: 0; transform: scale(.8); }
  30% { opacity: 1; transform: scale(1); }
  100% { opacity: 0; transform: scale(1.05); }
}

/* Botões de seek 10s — esconde em ao vivo via JS quando necessário */
#ctrl-back10, #ctrl-fwd10 {
  display: inline-flex;
}

/* Mobile: garante que controles fiquem clicáveis em fullscreen e botões maiores */
@media (max-width: 768px) {
  .seek-fb-inner { width: 76px; height: 76px; font-size: 22px; }
  #ctrl-back10 svg, #ctrl-fwd10 svg { width: 22px; height: 22px; }
}
