:root{
    --bg:#0B0B0B; --bg2:#141414; --surface:#1B1B1B; --surface2:#262626;
    --line:#333333; --line-soft:#222222;
    --amber:#E50914; --amber-soft:#F6121D; --amber-dim:#7A1014;
    --red:#E50914;
    --text:#F5F5F5; --muted:#A9A9A9; --muted2:#6E6E6E;
    --display:'Oswald',system-ui,sans-serif;
    --body:'Inter',system-ui,sans-serif;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    background:var(--bg); color:var(--text); font-family:var(--body);
    min-height:100vh; -webkit-font-smoothing:antialiased;
    background-image:radial-gradient(1200px 600px at 80% -10%, rgba(229,9,20,.10), transparent 60%);
  }

  /* ---------- Marquee header ---------- */
  header{ border-bottom:1px solid var(--line-soft); background:linear-gradient(180deg,var(--bg2),var(--bg)); position:relative; z-index:30; }
  .filmstrip{ height:14px; background:repeating-linear-gradient(90deg, transparent 0 10px, rgba(0,0,0,.55) 10px 14px, transparent 14px 24px); border-bottom:1px solid var(--line-soft); opacity:.6 }
  .bar{ max-width:1320px; margin:0 auto; padding:18px 24px 16px; display:flex; align-items:center; gap:22px; flex-wrap:wrap }
  .brand{ display:flex; align-items:baseline; gap:12px }
  .brand .dot{ width:9px;height:9px;border-radius:50%; background:var(--amber); box-shadow:0 0 14px 2px rgba(229,9,20,.7); align-self:center }
  .brand h1{ font-family:var(--display); font-weight:700; font-size:26px; letter-spacing:.08em; text-transform:uppercase }
  .brand h1 span{ color:var(--amber) }
  .brand .tag{ font-family:var(--display); font-weight:300; letter-spacing:.32em; text-transform:uppercase; font-size:11px; color:var(--muted2) }
  .stats{ margin-left:auto; display:flex; gap:26px }
  .stat{ text-align:center }
  .stat b{ font-family:var(--display); font-weight:600; font-size:22px; display:block; line-height:1; color:var(--text) }
  .stat span{ font-family:var(--display); font-weight:300; letter-spacing:.18em; text-transform:uppercase; font-size:10px; color:var(--muted) }

  /* ---------- Controls ---------- */
  .controls{ max-width:1320px; margin:0 auto; padding:16px 24px; display:flex; gap:12px; flex-wrap:wrap; align-items:center }
  .controls.hidden{ display:none }
  .search{ position:relative; flex:1 1 100% }
  .search input{ width:100%; background:var(--surface); border:1px solid var(--line); color:var(--text); padding:11px 14px 11px 40px; border-radius:10px; font-family:var(--body); font-size:14px; outline:none; transition:border-color .15s, box-shadow .15s }
  .search input::placeholder{ color:var(--muted2) }
  .search input:focus{ border-color:var(--amber-soft); box-shadow:0 0 0 3px rgba(229,9,20,.14) }
  .search svg{ position:absolute; left:13px; top:50%; transform:translateY(-50%); color:var(--muted2) }
  select{ background:var(--surface); border:1px solid var(--line); color:var(--text); padding:11px 14px; border-radius:10px; font-family:var(--body); font-size:14px; outline:none; cursor:pointer; max-width:260px }
  /* "Todas as categorias" ocupa a largura toda */
  .catdd{ flex:1 1 100%; }
  #year, #filtro{ flex:1 1 0; max-width:none }
  select:focus{ border-color:var(--amber-soft) }
  .seg{ display:flex; background:var(--surface); border:1px solid var(--line); border-radius:10px; overflow:hidden }
  .seg button{ background:transparent; border:none; color:var(--muted); font-family:var(--display); font-weight:500; letter-spacing:.06em; text-transform:uppercase; font-size:12px; padding:11px 16px; cursor:pointer; transition:color .15s, background .15s }
  .seg button[aria-pressed="true"]{ background:var(--amber); color:#ffffff }
  .seg button:not([aria-pressed="true"]):hover{ color:var(--text) }

  /* ---------- Dropzone ---------- */
  .stage{ max-width:1320px; margin:0 auto; padding:0 24px 60px }
  .drop{ position:relative; margin:48px auto; max-width:680px; border:1.5px dashed var(--line); border-radius:18px; background:linear-gradient(180deg,var(--surface),var(--bg2)); padding:54px 40px; text-align:center; transition:border-color .18s, background .18s }
  .drop.drag{ border-color:var(--amber); background:linear-gradient(180deg,rgba(229,9,20,.07),var(--bg2)) }
  .drop .reel{ font-size:42px; margin-bottom:8px; filter:saturate(.85) }
  .drop h2{ font-family:var(--display); font-weight:600; font-size:24px; letter-spacing:.04em; text-transform:uppercase; margin-bottom:10px }
  .drop p{ color:var(--muted); font-size:14px; line-height:1.6; max-width:440px; margin:0 auto 22px }
  .btn{ display:inline-block; background:var(--amber); color:#ffffff; font-family:var(--display); font-weight:600; letter-spacing:.06em; text-transform:uppercase; font-size:13px; padding:12px 26px; border-radius:10px; border:none; cursor:pointer; transition:transform .12s, box-shadow .15s }
  .btn:hover{ transform:translateY(-1px); box-shadow:0 8px 22px -8px rgba(229,9,20,.6) }
  .btn.ghost{ background:transparent; color:var(--amber); border:1px solid var(--amber-dim) }
  .btn.ghost:hover{ box-shadow:none; background:rgba(229,9,20,.08) }
  .privacy{ margin-top:20px; font-size:12px; color:var(--muted2); display:flex; gap:7px; align-items:center; justify-content:center }
  .privacy b{ color:var(--amber-soft); font-weight:600 }
  .or{ margin:18px 0; color:var(--muted2); font-family:var(--display); letter-spacing:.2em; font-size:11px; text-transform:uppercase }
  .urlrow{ display:flex; gap:8px; max-width:520px; margin:0 auto }
  .urlrow input{ flex:1; background:var(--bg); border:1px solid var(--line); color:var(--text); padding:11px 14px; border-radius:10px; font-size:13px; outline:none }
  .urlrow input:focus{ border-color:var(--amber-soft) }

  .sources{ display:flex; flex-direction:column; gap:8px; max-width:560px; margin:0 auto 14px; text-align:left }
  .srow{ display:flex; gap:7px; align-items:center; flex-wrap:wrap }
  .srow input{ background:var(--bg); border:1px solid var(--line); color:var(--text); padding:10px 12px; border-radius:9px; font-size:13px; outline:none; min-width:0 }
  .srow input::placeholder{ color:var(--muted2) }
  .srow input:focus{ border-color:var(--amber-soft) }
  .srow-name{ width:150px; flex:none }
  .srow-url{ flex:1 }
  .srow-url.hasfile{ color:var(--amber); border-color:var(--amber-dim) }
  .srow-btn{ flex:none; width:38px; height:38px; border-radius:9px; border:1px solid var(--line); background:var(--surface); color:var(--muted); cursor:pointer; font-size:14px; display:flex; align-items:center; justify-content:center }
  .srow-btn:hover{ color:var(--text); border-color:var(--muted2) }
  .srow-file.active{ color:var(--amber); border-color:var(--amber-dim); background:rgba(229,9,20,.08) }
  .srcbtns{ display:flex; gap:8px; justify-content:center; margin-bottom:8px }
  .dzclose{ position:absolute; top:12px; right:14px; background:transparent; border:1px solid var(--line); color:var(--muted); border-radius:8px; padding:6px 12px; font-family:var(--display); font-weight:400; letter-spacing:.06em; text-transform:uppercase; font-size:11px; cursor:pointer }
  .dzclose:hover{ color:var(--text); border-color:var(--muted2) }
  @media (max-width:560px){ .srow-name{ width:100%; flex:1 1 100% } }

  /* ---------- Grid ---------- */
  .grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(168px,1fr)); gap:20px 16px; padding-top:8px }
  .card{ position:relative; cursor:default; border-radius:12px; overflow:hidden; background:var(--surface2); aspect-ratio:2/3; box-shadow:0 1px 0 rgba(255,255,255,.02) inset; transition:transform .18s ease, box-shadow .18s ease }
  .card:hover{ transform:translateY(-6px); box-shadow:0 18px 34px -16px rgba(0,0,0,.8), 0 0 0 1px var(--amber-dim), 0 0 24px -6px rgba(229,9,20,.35) }
  .card img{ width:100%; height:100%; object-fit:cover; display:block; background:var(--surface) }
  .card .fallback{ position:absolute; inset:0; display:none; align-items:center; justify-content:center; padding:14px; text-align:center; background:linear-gradient(155deg,#3a2c20,#211913) }
  .card .fallback span{ font-family:var(--display); font-weight:600; font-size:15px; line-height:1.25; color:var(--amber-soft); letter-spacing:.02em }
  .card .scrim{ position:absolute; inset:0; background:linear-gradient(180deg,transparent 45%, rgba(10,7,5,.92) 100%); opacity:.85 }
  .meta{ position:absolute; left:0; right:0; bottom:0; padding:12px 12px 11px }
  .meta .name{ font-size:13px; font-weight:600; line-height:1.25; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; text-shadow:0 1px 4px rgba(0,0,0,.6) }
  .meta .cat{ margin-top:5px; font-family:var(--display); font-weight:400; font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--amber); opacity:.9; white-space:nowrap; overflow:hidden; text-overflow:ellipsis }
  .badge{ position:absolute; top:9px; left:9px; font-family:var(--display); font-weight:600; font-size:9px; letter-spacing:.1em; text-transform:uppercase; padding:3px 7px; border-radius:5px; background:rgba(20,14,10,.78); border:1px solid var(--line); color:var(--muted) }
  .badge.live{ color:#ffd9cf; border-color:rgba(201,69,59,.5); background:rgba(201,69,59,.22) }
  .badge.srv{ left:auto; right:9px; color:#ffd9db; border-color:var(--amber-dim); background:rgba(229,9,20,.18) }

  .psources{ position:relative; padding:11px 16px; border-bottom:1px solid var(--line-soft); background:var(--surface) }
  .srvtoggle{ font-family:var(--display); font-weight:500; letter-spacing:.05em; font-size:12.5px; padding:8px 15px; border-radius:9px; border:1px solid var(--amber-dim); background:var(--bg2); color:var(--amber-soft); cursor:pointer; transition:all .14s }
  .srvtoggle:hover{ border-color:var(--amber); color:var(--amber) }
  .srvmenu{ position:absolute; top:calc(100% - 4px); left:16px; z-index:6; min-width:264px; max-height:280px; overflow:auto; background:var(--bg2); border:1px solid var(--line); border-radius:10px; box-shadow:0 18px 40px -12px rgba(0,0,0,.75); padding:6px }
  .srvopt{ display:flex; align-items:center; justify-content:space-between; gap:10px; width:100%; text-align:left; font-family:var(--display); font-weight:500; letter-spacing:.04em; font-size:13px; padding:9px 12px; border-radius:7px; border:1px solid transparent; background:transparent; color:var(--muted); cursor:pointer; transition:all .12s }
  .srvopt:hover{ background:var(--surface2); color:var(--text) }
  .srvopt .srvtick{ opacity:0; color:var(--amber); font-size:12px }
  .srvopt[aria-pressed="true"]{ color:var(--amber); border-color:var(--amber-dim); background:rgba(229,9,20,.08) }
  .srvopt[aria-pressed="true"] .srvtick{ opacity:1 }

  .pactions{ display:flex; flex-wrap:wrap; gap:8px; padding:11px 16px; border-bottom:1px solid var(--line-soft); background:var(--bg2) }
  .pact{ display:inline-flex; align-items:center; gap:7px; font-family:var(--body); font-weight:500; font-size:13px; padding:8px 14px; border-radius:9px; border:1px solid var(--line); background:var(--surface); color:var(--muted); cursor:pointer; transition:all .14s }
  .pact span{ font-size:14px; line-height:1 }
  .pact:hover{ color:var(--text); border-color:var(--muted2) }
  .pact-cast{ color:var(--amber); border-color:var(--amber-dim); background:rgba(229,9,20,.10) }
  .pact-cast:hover{ color:var(--amber); background:rgba(229,9,20,.18) }
  .pact-cast.casting{ background:var(--amber); color:#ffffff; border-color:var(--amber) }
  .pact-stop{ color:var(--muted2); border-color:var(--line) }
  .pact-stop:hover{ color:var(--text); border-color:var(--muted) }
  .pact-stop.on{ color:#fff; background:var(--amber); border-color:var(--amber) }
  .pact-stop.on:hover{ background:var(--amber-soft) }
  google-cast-launcher{ width:30px; height:30px; --connected-color:var(--amber); --disconnected-color:var(--muted); cursor:pointer; display:none }
  google-cast-launcher.show{ display:inline-block }
  .pcastnote{ padding:10px 16px; background:rgba(229,9,20,.08); border-bottom:1px solid var(--line-soft); color:var(--amber); font-size:12.5px; line-height:1.5 }
  .pcastnote b{ color:var(--text) }
  .pcastnote code{ background:var(--bg); border:1px solid var(--line); border-radius:5px; padding:1px 6px; font-family:ui-monospace,monospace; font-size:11.5px; color:var(--text) }

  .card{ cursor:pointer }
  .playover{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity .18s; z-index:2 }
  .card:hover .playover, .card:focus-visible .playover{ opacity:1 }
  .pbtn{ width:54px; height:54px; border-radius:50%; background:rgba(229,9,20,.92); color:#ffffff; display:flex; align-items:center; justify-content:center; font-size:20px; padding-left:4px; box-shadow:0 6px 20px -4px rgba(0,0,0,.7) }

  /* ---------- Player modal ---------- */
  .player-modal{ position:fixed; inset:0; z-index:100; display:none }
  .player-modal.open{ display:block }
  .player-backdrop{ position:absolute; inset:0; background:rgba(8,5,3,.86); backdrop-filter:blur(4px) }
  .player-box{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:min(960px,94vw); background:var(--bg2); border:1px solid var(--line); border-radius:14px; overflow:hidden; box-shadow:0 30px 80px -20px rgba(0,0,0,.9) }
  .player-head{ display:flex; align-items:center; gap:14px; padding:13px 16px; border-bottom:1px solid var(--line-soft) }
  .ptitle{ font-family:var(--display); font-weight:500; letter-spacing:.03em; font-size:16px; flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap }
  .pclose{ background:transparent; border:1px solid var(--line); color:var(--muted); width:34px; height:34px; border-radius:8px; cursor:pointer; font-size:15px; flex-shrink:0 }
  .pclose:hover{ color:var(--text); border-color:var(--muted2) }
  .player-stage{ position:relative; background:#000; aspect-ratio:16/9; display:flex; align-items:center; justify-content:center }
  .player-stage video{ width:100%; height:100%; background:#000 }
  .player-error{ padding:34px 28px; text-align:center; max-width:560px }
  .player-error h4{ font-family:var(--display); font-weight:500; letter-spacing:.03em; text-transform:uppercase; font-size:17px; margin-bottom:10px; color:var(--amber) }
  .player-error p{ color:var(--muted); font-size:14px; line-height:1.6; margin-bottom:16px }
  .urlbox{ background:var(--bg); border:1px solid var(--line); border-radius:8px; padding:10px 12px; margin-bottom:16px; max-height:80px; overflow:auto }
  .urlbox code{ font-size:12px; color:var(--muted); word-break:break-all; font-family:ui-monospace,monospace }

  .sentinel{ height:1px }
  .empty{ text-align:center; padding:70px 20px; color:var(--muted) }
  .empty p{ margin-top:8px; font-size:14px }
  .empty h3{ font-family:var(--display); font-weight:500; letter-spacing:.05em; text-transform:uppercase; font-size:18px }

  .reset{ background:transparent; border:1px solid var(--line); color:var(--muted); font-family:var(--display); letter-spacing:.06em; text-transform:uppercase; font-size:11px; padding:11px 14px; border-radius:10px; cursor:pointer }
  .reset:hover{ color:var(--text); border-color:var(--muted2) }
  .reset.addmore{ color:var(--amber); border-color:var(--amber-dim) }
  .reset.addmore:hover{ color:var(--amber); background:rgba(229,9,20,.08) }

  /* ---------- Lists panel ---------- */
  .listspanel{ display:flex; align-items:center; gap:14px; padding:8px 0 20px }
  .listsum{ flex:1; min-width:0; font-family:var(--display); font-weight:400; letter-spacing:.06em; text-transform:uppercase; font-size:12px; color:var(--muted); line-height:1.4 }
  .lists{ display:flex; flex-wrap:wrap; gap:8px }
  .listchip{ display:inline-flex; align-items:center; gap:9px; background:var(--surface); border:1px solid var(--line); border-radius:8px; padding:6px 11px; font-size:12px }
  .listchip b{ font-weight:600; color:var(--text); max-width:240px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap }
  .listchip i{ font-style:normal; color:var(--amber); font-family:var(--display); font-weight:500; letter-spacing:.04em }

  /* ---------- Section blocks ---------- */
  .section-head{ grid-column:1/-1; display:flex; align-items:baseline; gap:14px; padding:16px 2px 4px; margin-top:14px; border-bottom:1px solid var(--line-soft) }
  .section-head:first-child{ margin-top:0 }
  .sh-label{ font-family:var(--display); font-weight:600; letter-spacing:.06em; text-transform:uppercase; font-size:21px; color:var(--text); display:flex; align-items:center; gap:11px }
  .sh-label::before{ content:''; width:8px; height:8px; border-radius:50%; background:var(--amber); box-shadow:0 0 11px 1px rgba(229,9,20,.6) }
  .sh-count{ font-family:var(--display); font-weight:300; letter-spacing:.16em; text-transform:uppercase; font-size:11px; color:var(--muted) }

  @media (max-width:640px){
    .grid{ grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); gap:14px 10px }
    .bar{ flex-direction:column; align-items:center; text-align:center; gap:16px; padding:16px 18px 14px }
    .brand{ justify-content:center }
    .stats{ width:100%; margin-left:0; justify-content:center; gap:30px }
    .stat{ text-align:center }
    .controls{ padding:14px 18px }
  }
  @media (prefers-reduced-motion:reduce){ *{transition:none!important; scroll-behavior:auto} .card:hover{transform:none} }
  :focus-visible{ outline:2px solid var(--amber); outline-offset:2px }

  /* ---------- Série: badge de episódios + ícone de pasta ---------- */
  .badge.ep{ left:auto; right:9px; color:#cfe9ff; border-color:rgba(120,160,200,.4); background:rgba(40,60,90,.5) }
  .pbtn.folder{ background:rgba(20,14,10,.82); color:var(--amber); border:1px solid var(--amber-dim); font-size:22px; padding-left:0 }

  /* ---------- Modal de detalhes ---------- */
  .detail-modal{ position:fixed; inset:0; z-index:90; display:none }
  .detail-modal.open{ display:block }
  .detail-backdrop{ position:absolute; inset:0; background:rgba(8,5,3,.86); backdrop-filter:blur(4px) }
  .detail-box{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:min(860px,94vw); max-height:90vh; overflow:auto; background:var(--bg2); border:1px solid var(--line); border-radius:16px; box-shadow:0 30px 80px -20px rgba(0,0,0,.9) }
  .dclose{ position:absolute; top:14px; right:14px; z-index:3 }
  .detail-hero{ display:flex; gap:22px; padding:24px; align-items:flex-start }
  .dposter-wrap{ flex:none; width:150px; aspect-ratio:2/3; border-radius:12px; overflow:hidden; background:var(--surface2); box-shadow:0 10px 26px -12px rgba(0,0,0,.7) }
  .dposter{ width:100%; height:100%; object-fit:cover; display:block }
  .dposter-fallback{ width:100%; height:100%; display:none; align-items:center; justify-content:center; text-align:center; padding:12px; font-family:var(--display); font-weight:600; color:var(--amber-soft); background:linear-gradient(155deg,#3a2c20,#211913) }
  .dinfo{ flex:1; min-width:0 }
  .dinfo h2{ font-family:var(--display); font-weight:600; letter-spacing:.02em; font-size:25px; line-height:1.15; margin-bottom:10px }
  .dmeta{ display:flex; flex-wrap:wrap; gap:7px; margin-bottom:14px }
  .dtag{ font-family:var(--display); font-weight:400; letter-spacing:.04em; font-size:12px; padding:4px 10px; border-radius:7px; background:var(--surface); border:1px solid var(--line); color:var(--muted) }
  .dtag.cat{ color:var(--amber); border-color:var(--amber-dim) }
  .dsynopsis{ font-size:14px; line-height:1.65; color:var(--text); opacity:.92; margin-bottom:18px }
  .dactions .play-btn{ font-size:14px; padding:12px 26px }

  .depisodes{ padding:0 24px 24px }
  .seasons{ display:flex; flex-wrap:wrap; gap:7px; margin-bottom:14px; border-top:1px solid var(--line-soft); padding-top:18px }
  .seasonbtn{ font-family:var(--display); font-weight:500; letter-spacing:.06em; font-size:13px; padding:7px 15px; border-radius:8px; border:1px solid var(--line); background:var(--surface); color:var(--muted); cursor:pointer; transition:all .14s }
  .seasonbtn:hover{ color:var(--text); border-color:var(--muted2) }
  .seasonbtn[aria-pressed="true"]{ background:var(--amber); color:#ffffff; border-color:var(--amber) }
  .eplist{ display:flex; flex-direction:column; gap:6px }
  .eprow{ display:flex; align-items:flex-start; gap:12px; width:100%; text-align:left; background:var(--surface); border:1px solid var(--line-soft); border-radius:10px; padding:10px 12px; color:var(--text); cursor:pointer; transition:all .14s }
  .eprow:hover{ border-color:var(--amber-dim); background:var(--surface2) }
  .epstill{ flex:none; width:84px; aspect-ratio:16/9; border-radius:7px; background:var(--surface2) center/cover no-repeat; display:none }
  .epstill.has{ display:block }
  .epmain{ flex:1; min-width:0; display:flex; flex-direction:column; gap:3px }
  .eptop{ display:flex; align-items:baseline; gap:8px; flex-wrap:wrap }
  .epnum{ flex:none; font-family:var(--display); font-weight:600; letter-spacing:.04em; font-size:12px; color:var(--amber) }
  .epname{ font-size:13.5px; color:var(--text); overflow:hidden; text-overflow:ellipsis }
  .epsyn{ font-size:12px; line-height:1.5; color:var(--muted); display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden }
  .epsyn:empty{ display:none }
  .epserv{ flex:none; align-self:center; font-family:var(--display); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:#ffd9db; border:1px solid var(--amber-dim); border-radius:5px; padding:2px 7px }
  .epplay{ flex:none; align-self:center; color:var(--amber); font-size:13px }

  @media (max-width:560px){
    .detail-hero{ flex-direction:column; align-items:center; text-align:center }
    .dmeta{ justify-content:center }
    .dposter-wrap{ width:130px }
    .epstill{ width:64px }
    .epname{ font-size:12.5px }
  }

  /* nota do TMDB no canto da capa */
  .badge.rate{ left:9px; right:auto; color:#ffe9a8; border-color:rgba(229,9,20,.45); background:rgba(60,42,14,.7) }

  /* Botão "tocar" quando o navegador bloqueia o autoplay */
  .tapplay{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:84px; height:84px; border-radius:50%; border:none; cursor:pointer; font-size:34px; color:#ffffff; background:rgba(229,9,20,.95); box-shadow:0 10px 30px -6px rgba(0,0,0,.6); align-items:center; justify-content:center; padding-left:6px; z-index:4 }
  .tapplay:hover{ background:var(--amber) }

  /* Chips de categorias principais (topo da busca) */
  .chips{ max-width:1320px; margin:0 auto; padding:0 24px 14px; display:flex; gap:8px; flex-wrap:nowrap; overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:thin }
  .chips::-webkit-scrollbar{ height:6px }
  .chips::-webkit-scrollbar-thumb{ background:var(--line); border-radius:6px }
  .chip{ flex:0 0 auto; background:var(--surface); border:1px solid var(--line); color:var(--muted); font-family:var(--display); font-weight:500; letter-spacing:.04em; font-size:12.5px; padding:8px 15px; border-radius:999px; cursor:pointer; white-space:nowrap; transition:all .14s }
  .chip:hover{ color:var(--text); border-color:var(--muted2) }
  .chip[aria-pressed="true"]{ background:var(--amber); color:#ffffff; border-color:var(--amber); font-weight:700 }
  @media (max-width:640px){ .chips{ padding:0 16px 12px } }

  /* Chips criados por você (verde) + separador */
  .chip.chipcreated{ border-color:#3ddc84; color:#3ddc84 }
  .chip.chipcreated[aria-pressed="true"]{ background:#3ddc84; color:#06281a; border-color:#3ddc84 }
  .chipsep{ flex:0 0 auto; width:1px; align-self:stretch; margin:4px 4px; background:var(--line) }

  /* Botão Legendados (toggle) */
  .legbtn{ background:var(--surface); border:1px solid var(--line); color:var(--muted); font-family:var(--display); font-weight:500; letter-spacing:.04em; font-size:13px; padding:10px 16px; border-radius:10px; cursor:pointer; white-space:nowrap; transition:all .15s }
  .legbtn:hover{ color:var(--text); border-color:var(--muted2) }
  .legbtn[aria-pressed="true"]{ background:var(--amber); color:#ffffff; border-color:var(--amber); font-weight:700 }

  /* Info de servidores disponíveis no player */
  .srvinfo{ font-size:12.5px; color:var(--muted); margin-top:7px; letter-spacing:.02em }

  /* ===== Rodapé de navegação (estilo app/Netflix) ===== */
  body{ padding-bottom:76px }
  .botnav{ position:fixed; left:0; right:0; bottom:0; z-index:60; display:flex; justify-content:center; gap:6px; background:rgba(14,10,8,.97); backdrop-filter:blur(10px); border-top:1px solid var(--line); padding:9px 10px calc(9px + env(safe-area-inset-bottom)) }
  .navbtn{ flex:1; max-width:170px; display:flex; flex-direction:column; align-items:center; gap:3px; background:transparent; border:none; color:var(--muted); font-family:var(--display); font-size:11px; font-weight:500; letter-spacing:.07em; text-transform:uppercase; padding:5px 4px; cursor:pointer; border-radius:10px; transition:color .15s }
  .navbtn .ni{ display:flex; align-items:center; justify-content:center; height:22px }
  .navbtn .ni svg{ width:22px; height:22px }
  .navbtn .nl{ line-height:1 }
  .navbtn:hover{ color:var(--text) }
  .navbtn.active{ color:var(--amber) }
  

  /* ===== Home / carrosséis ===== */
  #home{ padding-top:6px }
  .hrow{ margin:6px 0 26px }
  .hrow-title{ font-family:var(--display); font-size:17px; font-weight:600; letter-spacing:.02em; margin:0 0 12px; color:var(--text) }
  .carousel{ display:flex; gap:14px; overflow-x:auto; padding:4px 2px 10px; scroll-snap-type:x proximity; -webkit-overflow-scrolling:touch; scrollbar-width:none; -ms-overflow-style:none }
  .carousel-wrap{ position:relative }
  .crsl-nav{ position:absolute; top:0; bottom:14px; width:48px; display:none; align-items:center; justify-content:center; z-index:4; border:none; cursor:pointer; color:#fff; font-size:30px; line-height:1; opacity:0; transition:opacity .15s }
  .crsl-nav.prev{ left:0; border-radius:12px 0 0 12px; background:linear-gradient(90deg, rgba(11,11,11,.9), rgba(11,11,11,.1)) }
  .crsl-nav.next{ right:0; border-radius:0 12px 12px 0; background:linear-gradient(270deg, rgba(11,11,11,.9), rgba(11,11,11,.1)) }
  .crsl-nav:hover{ color:var(--amber) }
  .carousel-wrap:hover .crsl-nav{ opacity:1 }
  .carousel.dragging{ scroll-behavior:auto; scroll-snap-type:none }
  /* setas + cursor de arrastar só no desktop (com mouse); no mobile fica o touch */
  @media (hover:hover) and (min-width:641px){
    .crsl-nav{ display:flex }
    .carousel{ cursor:grab }
    .carousel.dragging{ cursor:grabbing }
    .carousel.dragging .ccard{ pointer-events:none }
  }
  .carousel::-webkit-scrollbar{ display:none; width:0; height:0 }
  .ccard{ flex:0 0 auto; width:152px; scroll-snap-align:start; cursor:pointer }
  .ccard .rank{ position:absolute; top:6px; left:7px; z-index:4; font-family:var(--display); font-weight:800; font-size:22px; line-height:1; color:#fff; -webkit-text-stroke:1.6px rgba(0,0,0,.6); text-shadow:0 2px 8px rgba(0,0,0,.7) }
  .ccard .badge.srv, .ccard .badge.ep{ display:none }
  .ccard .badge.rate{ left:auto; right:7px; top:7px }
  @media (max-width:640px){ .ccard{ width:132px } .hrow-title{ font-size:15px } .carousel{ gap:11px } }

  /* ===== Animação de carregamento do player ===== */
  .player-loader{ position:absolute; inset:0; z-index:3; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:18px; background:#000; animation:plfade .2s ease }
  .ploader-ring{ width:56px; height:56px; border-radius:50%; border:3px solid rgba(255,255,255,.14); border-top-color:var(--amber); border-right-color:var(--amber); animation:plspin .8s linear infinite; box-shadow:0 0 22px -4px rgba(229,9,20,.55) }
  .ploader-txt{ font-family:var(--display); font-weight:400; letter-spacing:.22em; text-transform:uppercase; font-size:11px; color:var(--muted); animation:plpulse 1.4s ease-in-out infinite }
  @keyframes plspin{ to{ transform:rotate(360deg) } }
  @keyframes plpulse{ 0%,100%{ opacity:.45 } 50%{ opacity:1 } }
  @keyframes plfade{ from{ opacity:0 } to{ opacity:1 } }

  /* ===== Dropdown de categorias (custom, tema vermelho/preto) ===== */
  .catdd{ position:relative }
  .catdd-btn{ width:100%; display:flex; align-items:center; justify-content:center; gap:10px; position:relative; background:var(--surface); border:1px solid var(--line); color:var(--text); padding:12px 38px; border-radius:10px; font-family:var(--body); font-size:14px; font-weight:500; cursor:pointer; transition:border-color .15s, box-shadow .15s }
  .catdd-btn:hover{ border-color:var(--amber-dim) }
  .catdd-btn.open{ border-color:var(--amber-soft); box-shadow:0 0 0 3px rgba(229,9,20,.14) }
  .catdd-arrow{ position:absolute; right:16px; color:var(--muted); font-size:12px; transition:transform .18s, color .15s }
  .catdd-btn.open .catdd-arrow{ transform:rotate(180deg); color:var(--amber) }
  .catdd-panel{ position:absolute; left:0; right:0; top:calc(100% + 6px); z-index:45; background:var(--bg2); border:1px solid var(--line); border-radius:12px; padding:6px; max-height:344px; overflow-y:auto; box-shadow:0 18px 44px -12px rgba(0,0,0,.85); scrollbar-width:thin }
  .catdd-panel::-webkit-scrollbar{ width:8px }
  .catdd-panel::-webkit-scrollbar-thumb{ background:var(--line); border-radius:6px }
  .catdd-opt{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:12px; background:transparent; border:none; color:var(--text); font-family:var(--body); font-size:14px; text-align:left; padding:11px 14px; border-radius:8px; cursor:pointer; transition:background .12s, color .12s }
  .catdd-opt:hover{ background:var(--surface2) }
  .catdd-opt.on{ background:rgba(229,9,20,.16); color:var(--amber); font-weight:600 }
  .co-name{ white-space:nowrap; overflow:hidden; text-overflow:ellipsis }
  .co-count{ flex:none; font-family:var(--display); font-weight:500; font-size:12px; letter-spacing:.03em; color:var(--muted); background:var(--surface); border:1px solid var(--line); border-radius:20px; padding:2px 10px; min-width:34px; text-align:center }
  .catdd-opt:hover .co-count{ border-color:var(--amber-dim) }
  .catdd-opt.on .co-count{ color:var(--amber); border-color:var(--amber-dim); background:rgba(229,9,20,.1) }

  /* ===== Selo de qualidade (resolução real do vídeo) ===== */
  .qbadge{ flex:none; font-family:var(--display); font-weight:600; font-size:11px; letter-spacing:.08em; text-transform:uppercase; padding:4px 10px; border-radius:6px; border:1px solid var(--line); color:var(--muted); background:var(--surface); white-space:nowrap }
  .qbadge.q4k{ color:#fff; background:var(--amber); border-color:var(--amber) }
  .qbadge.qfhd{ color:var(--amber); background:rgba(229,9,20,.14); border-color:var(--amber-dim) }
  .qbadge.qhd{ color:var(--text); background:var(--surface2); border-color:var(--line) }
  .qbadge.qsd{ color:var(--muted2); background:var(--surface); border-color:var(--line-soft) }

  /* ===== Qualidade por servidor (na lista) ===== */
  .srvopt .srvname{ flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap }
  .srvq{ flex:none; font-family:var(--display); font-weight:600; font-size:10px; letter-spacing:.05em; text-transform:uppercase; padding:2px 7px; border-radius:5px; border:1px solid var(--line); color:var(--muted); background:var(--surface) }
  .srvq.q4k{ color:#fff; background:var(--amber); border-color:var(--amber) }
  .srvq.qfhd{ color:var(--amber); background:rgba(229,9,20,.14); border-color:var(--amber-dim) }
  .srvq.qhd{ color:var(--text); background:var(--surface2); border-color:var(--line) }
  .srvq.qsd{ color:var(--muted2); background:var(--surface) }
  .srvq.qan{ color:var(--muted2); background:transparent; border-color:transparent; font-family:var(--body); font-weight:400; font-size:11px; letter-spacing:0; text-transform:none; font-style:italic }
  .srvq.qna{ color:var(--muted2); background:transparent; border-color:var(--line-soft); font-family:var(--body); font-weight:400; font-size:10px; letter-spacing:0; text-transform:none }

  /* ===== Botões da tela de carregamento (rápido vs qualidade) ===== */
  .ploader-actions{ display:flex; gap:12px; margin-top:6px; flex-wrap:wrap; justify-content:center }
  .plbtn{ display:inline-flex; align-items:center; gap:7px; font-family:var(--display); font-weight:600; letter-spacing:.05em; text-transform:uppercase; font-size:12.5px; padding:11px 20px; border-radius:9px; cursor:pointer; transition:transform .12s, background .15s, border-color .15s }
  .plbtn span{ font-size:14px }
  .plbtn-fast{ background:var(--surface2); border:1px solid var(--line); color:var(--text) }
  .plbtn-fast:hover{ border-color:var(--muted); transform:translateY(-1px) }
  .plbtn-hd{ background:var(--amber); border:1px solid var(--amber); color:#fff }
  .plbtn-hd:hover{ background:var(--amber-soft); transform:translateY(-1px) }

  /* pontinhos animados de carregando */
  .ldots::after{ content:''; animation:ldots 1.3s steps(1,end) infinite }
  @keyframes ldots{ 0%{content:''} 25%{content:'.'} 50%{content:'..'} 75%{content:'...'} 100%{content:'...'} }

  /* ===== Banner hero rotativo (Home) ===== */
  .hero{ position:relative; margin:2px 0 30px; border-radius:16px; overflow:hidden; background:var(--surface2) }
  .hero-viewport{ overflow:hidden; touch-action:pan-y; cursor:grab }
  .hero-viewport:active{ cursor:grabbing }
  .hero-track{ display:flex; will-change:transform }
  .hero-slide{ position:relative; flex:0 0 100%; height:clamp(232px,44vw,460px); user-select:none }
  .hs-bg{ position:absolute; inset:0; background-size:cover; background-position:center 18%; pointer-events:none }
  .hs-scrim{ position:absolute; inset:0; pointer-events:none; background:linear-gradient(90deg, rgba(11,11,11,.94) 0%, rgba(11,11,11,.62) 36%, rgba(11,11,11,.12) 68%, rgba(11,11,11,.55) 100%), linear-gradient(0deg, rgba(11,11,11,.96) 2%, transparent 52%) }
  .hs-body{ position:absolute; left:0; bottom:0; padding:clamp(18px,3.4vw,40px); max-width:680px; z-index:2 }
  .hs-meta{ display:flex; align-items:center; gap:12px; margin-bottom:9px; flex-wrap:wrap }
  .hs-cat{ font-family:var(--display); font-weight:600; letter-spacing:.14em; text-transform:uppercase; font-size:11px; color:var(--amber) }
  .hs-year{ color:var(--muted); font-size:13px }
  .hs-rate{ color:#ffd76a; font-size:13px; font-weight:600 }
  .hs-title{ font-family:var(--display); font-weight:600; font-size:clamp(24px,4.4vw,46px); line-height:1.05; margin:0 0 10px; text-shadow:0 2px 16px rgba(0,0,0,.65) }
  .hs-ov{ color:var(--text); opacity:.85; font-size:14px; line-height:1.5; max-width:560px; margin:0 0 16px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden }
  .hs-actions{ display:flex; gap:12px }
  .hs-play{ display:inline-flex; align-items:center; gap:8px; background:var(--amber); color:#fff; border:none; font-family:var(--display); font-weight:600; letter-spacing:.04em; text-transform:uppercase; font-size:14px; padding:12px 26px; border-radius:9px; cursor:pointer; transition:background .15s, transform .12s }
  .hs-play:hover{ background:var(--amber-soft); transform:translateY(-1px) }
  .hero-nav{ position:absolute; top:50%; transform:translateY(-50%); z-index:5; width:44px; height:44px; border-radius:50%; border:1px solid rgba(255,255,255,.18); background:rgba(0,0,0,.42); color:#fff; font-size:26px; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center; backdrop-filter:blur(4px); transition:background .15s, border-color .15s }
  .hero-nav:hover{ background:rgba(229,9,20,.82); border-color:transparent }
  .hero-nav.prev{ left:14px } .hero-nav.next{ right:14px }
  .hero-dots{ position:absolute; bottom:14px; left:50%; transform:translateX(-50%); z-index:5; display:flex; gap:8px }
  .hero-dot{ width:8px; height:8px; border-radius:50%; border:none; background:rgba(255,255,255,.38); cursor:pointer; padding:0; transition:background .15s, width .15s }
  .hero-dot.on{ background:var(--amber); width:22px; border-radius:5px }
  @media (max-width:640px){ .hero{ border-radius:12px; margin-bottom:22px } .hero-nav{ width:36px; height:36px; font-size:21px } .hs-ov{ display:none } }

  /* ===== Gaveta lateral de filtros + tag Buscar ===== */
  .filterbtn{ display:inline-flex; align-items:center; gap:7px; flex:none; background:var(--amber); color:#fff; border:none; font-family:var(--display); font-weight:600; letter-spacing:.05em; text-transform:uppercase; font-size:12px; padding:9px 16px; border-radius:8px; cursor:pointer; transition:background .15s, transform .12s }
  .filterbtn:hover{ background:var(--amber-soft); transform:translateY(-1px) }
  .filterbtn svg{ display:block }
  .filter-backdrop{ position:fixed; inset:0; z-index:75; background:rgba(0,0,0,.55); backdrop-filter:blur(2px); opacity:0; visibility:hidden; transition:opacity .25s, visibility .25s }
  .filter-backdrop.show{ opacity:1; visibility:visible }
  .filterdrawer{ position:fixed; top:0; right:0; height:100%; width:min(360px,86vw); z-index:80; background:var(--bg2); border-left:1px solid var(--line); box-shadow:-22px 0 54px -22px rgba(0,0,0,.75); transform:translateX(100%); transition:transform .28s cubic-bezier(.22,.61,.36,1); display:flex; flex-direction:column; overflow:hidden }
  .filterdrawer.open{ transform:translateX(0) }
  .fd-head{ display:flex; align-items:center; justify-content:space-between; padding:18px 20px; border-bottom:1px solid var(--line-soft); flex:none }
  .fd-title{ font-family:var(--display); font-weight:600; letter-spacing:.08em; text-transform:uppercase; font-size:14px; color:var(--text) }
  .fd-close{ background:transparent; border:1px solid var(--line); color:var(--muted); width:32px; height:32px; border-radius:8px; cursor:pointer; font-size:14px }
  .fd-close:hover{ color:var(--text); border-color:var(--muted) }
  .fd-body{ display:flex; flex-direction:column; gap:14px; padding:18px 20px; overflow-y:auto }
  .fd-body .search{ flex:1 1 auto; width:100% }
  .fd-body #year, .fd-body #filtro{ width:100%; max-width:none }
  .fd-body .catdd{ width:100% }
  .fd-body .catdd-panel{ position:static; box-shadow:none; margin-top:6px; max-height:260px }

  /* ===== Banner de compra (vitrine / bloqueio de reprodução) ===== */
  .paywall{ position:fixed; inset:0; z-index:120; display:none; align-items:center; justify-content:center; padding:24px }
  .paywall.open{ display:flex }
  .paywall-backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.78); backdrop-filter:blur(6px) }
  .paywall-box{ position:relative; z-index:1; width:100%; max-width:440px; background:linear-gradient(180deg,var(--surface),var(--bg2)); border:1px solid var(--line); border-radius:18px; padding:38px 30px 30px; text-align:center; box-shadow:0 30px 80px -20px rgba(0,0,0,.85), 0 0 0 1px rgba(229,9,20,.08); animation:pwin .25s ease }
  @keyframes pwin{ from{ opacity:0; transform:translateY(10px) scale(.98) } to{ opacity:1; transform:none } }
  .paywall-close{ position:absolute; top:14px; right:14px; width:32px; height:32px; border-radius:8px; border:1px solid var(--line); background:transparent; color:var(--muted); cursor:pointer; font-size:14px }
  .paywall-close:hover{ color:var(--text); border-color:var(--muted) }
  .paywall-icon{ font-size:40px; margin-bottom:8px; filter:drop-shadow(0 0 18px rgba(229,9,20,.5)) }
  .paywall-title{ font-family:var(--display); font-weight:700; letter-spacing:.04em; text-transform:uppercase; font-size:24px; color:var(--text); margin:0 0 12px }
  .paywall-sub{ color:var(--muted); font-size:15px; line-height:1.55; margin:0 auto 24px; max-width:360px }
  .paywall-sub b{ color:var(--text); font-weight:600 }
  .paywall-btn{ display:block; width:100%; background:var(--amber); color:#fff; text-decoration:none; font-family:var(--display); font-weight:600; letter-spacing:.05em; text-transform:uppercase; font-size:16px; padding:16px 20px; border-radius:11px; box-shadow:0 12px 30px -8px rgba(229,9,20,.6); transition:background .15s, transform .12s }
  .paywall-btn:hover{ background:var(--amber-soft); transform:translateY(-1px) }
  .paywall-note{ color:var(--muted2); font-size:12.5px; margin:14px 0 0; letter-spacing:.02em }

  /* ===== Favoritos ===== */
  .dfav{ display:inline-flex; align-items:center; gap:8px; margin-top:14px; background:var(--surface2); border:1px solid var(--line); color:var(--text); font-family:var(--display); font-weight:600; letter-spacing:.05em; text-transform:uppercase; font-size:13px; padding:10px 18px; border-radius:9px; cursor:pointer; transition:all .15s }
  .dfav:hover{ border-color:var(--amber-dim) }
  .dfav .dfav-star{ font-size:17px; line-height:1; color:var(--muted) }
  .dfav.on{ background:rgba(229,9,20,.14); border-color:var(--amber-dim); color:var(--amber) }
  .dfav.on .dfav-star{ color:#ffd24a }
  .favtitle{ font-family:var(--display); font-size:20px; font-weight:600; letter-spacing:.02em; margin:6px 0 18px; color:var(--text) }

  /* ===== Tela de login (e-mail autorizado) ===== */
  .login-screen{ position:fixed; inset:0; z-index:200; display:none; align-items:center; justify-content:center; padding:24px; background:radial-gradient(1200px 600px at 50% -10%, rgba(229,9,20,.16), transparent 60%), var(--bg) }
  .login-screen.open{ display:flex }
  .login-box{ width:100%; max-width:380px; background:linear-gradient(180deg,var(--surface),var(--bg2)); border:1px solid var(--line); border-radius:18px; padding:34px 28px; text-align:center; box-shadow:0 30px 80px -20px rgba(0,0,0,.85) }
  .login-brand{ font-family:var(--display); font-weight:700; letter-spacing:.04em; font-size:22px; color:var(--text); display:flex; align-items:center; justify-content:center; gap:9px; margin-bottom:22px }
  .login-brand span:last-child{ color:var(--amber) }
  .login-brand .dot{ width:9px; height:9px; border-radius:50%; background:var(--amber); box-shadow:0 0 12px var(--amber) }
  .login-title{ font-family:var(--display); font-weight:600; font-size:20px; margin:0 0 8px; color:var(--text) }
  .login-sub{ color:var(--muted); font-size:14px; margin:0 0 22px }
  .login-input{ width:100%; background:var(--bg); border:1px solid var(--line); color:var(--text); font-size:15px; padding:14px 16px; border-radius:11px; outline:none; transition:border-color .15s; box-sizing:border-box }
  .login-input:focus{ border-color:var(--amber-dim) }
  .login-btn{ width:100%; margin-top:12px; background:var(--amber); color:#fff; border:none; font-family:var(--display); font-weight:600; letter-spacing:.05em; text-transform:uppercase; font-size:15px; padding:14px 20px; border-radius:11px; cursor:pointer; transition:background .15s, transform .12s }
  .login-btn:hover{ background:var(--amber-soft); transform:translateY(-1px) }
  .login-btn:disabled{ opacity:.6; cursor:default; transform:none }
  .login-msg{ min-height:18px; margin:14px 0 0; font-size:13px; color:var(--muted) }
  .login-msg.err{ color:#ff6b6b }

/* ===== Modal de bloqueio +18 ===== */
.adult-overlay{ position:fixed; inset:0; z-index:300; display:flex; align-items:center; justify-content:center; padding:24px; background:radial-gradient(1200px 600px at 50% -10%, rgba(229,9,20,.18), transparent 60%), rgba(0,0,0,.82); backdrop-filter:blur(4px) }
.adult-box{ width:100%; max-width:360px; background:linear-gradient(180deg,var(--surface),var(--bg2)); border:1px solid var(--line); border-radius:18px; padding:30px 26px; text-align:center; box-shadow:0 30px 80px -20px rgba(0,0,0,.85) }
.adult-ic{ font-size:40px; line-height:1; margin-bottom:10px }
.adult-box h3{ margin:0 0 6px; font-family:var(--display); font-size:20px; color:var(--text) }
.adult-box p{ margin:0 0 16px; color:var(--muted); font-size:14px }
.adult-input{ width:100%; background:var(--bg); border:1px solid var(--line); color:var(--text); font-size:15px; padding:13px 15px; border-radius:11px; outline:none; transition:border-color .15s; box-sizing:border-box }
.adult-input:focus{ border-color:var(--amber-dim) }
.adult-msg{ min-height:18px; margin:8px 0 0; font-size:13px; color:var(--amber-soft) }
.adult-actions{ display:flex; gap:10px; margin-top:14px }
.adult-btn{ flex:1; border:none; font-family:var(--display); font-weight:600; letter-spacing:.05em; text-transform:uppercase; font-size:14px; padding:13px 16px; border-radius:11px; cursor:pointer; transition:background .15s, transform .12s }
.adult-btn.ok{ background:var(--amber); color:#fff } .adult-btn.ok:hover{ background:var(--amber-soft); transform:translateY(-1px) }
.adult-btn.cancel{ background:transparent; color:var(--muted); border:1px solid var(--line) } .adult-btn.cancel:hover{ color:var(--text); border-color:var(--muted2) }
