*{box-sizing:border-box;margin:0;padding:0}
:root{--brand:#16a34a;--brand2:#22c55e;--bg:#0a0f1c;--surf:#111a30;--surf2:#16203a;--muted:#7b86a0;--txt:#e6ecff}
html,body{height:100%;background:var(--bg);color:var(--txt);font-family:'Inter',system-ui,Arial,sans-serif;overflow:hidden}
.hidden{display:none !important}
.boot{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--muted);font-size:20px}

/* Player */
.player-layer{position:fixed;inset:0;background:#000;z-index:100}
#video{width:100%;height:100%;background:#000}
.player-back{position:fixed;top:18px;left:18px;z-index:101;background:rgba(0,0,0,.6);color:#fff;border:none;
  padding:12px 20px;border-radius:10px;font-size:16px;cursor:pointer}
.player-back:hover,.player-back.focused{background:var(--brand)}

/* Acesso/Login */
.screen{min-height:100vh;padding:32px 24px;overflow-y:auto}
.brand{display:flex;align-items:center;gap:14px;margin-bottom:26px}
.brand .logo{width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,var(--brand),var(--brand2));
  display:flex;align-items:center;justify-content:center;font-size:28px}
.brand h1{font-size:26px;font-weight:800}.brand small{color:var(--muted);font-size:14px}
.tabs{display:flex;gap:10px;margin-bottom:22px;flex-wrap:wrap}
.tab{padding:12px 22px;border-radius:10px;background:var(--surf2);color:var(--muted);font-size:16px;cursor:pointer}
.tab.active{background:var(--brand);color:#fff;font-weight:700}
.macbox{background:var(--surf);border:1px solid #1e2a4a;border-radius:16px;padding:26px;max-width:680px}
.macbox .label{color:var(--muted);font-size:14px;margin-bottom:8px}
.macbox .mac{font-size:34px;font-weight:800;color:var(--brand2);font-family:monospace;word-break:break-all}
.macbox p{color:#b7c2dc;font-size:15px;margin-top:14px;line-height:1.5}
.field{margin-bottom:16px;max-width:520px}.field label{display:block;color:#b7c2dc;font-size:15px;margin-bottom:6px}
.field input{width:100%;padding:14px 16px;font-size:17px;border-radius:10px;border:2px solid #1e2a4a;background:#0d1424;color:#fff}
.field input:focus{outline:none;border-color:var(--brand)}
.btn{display:inline-block;padding:14px 32px;font-size:17px;font-weight:700;color:#fff;border:none;border-radius:10px;cursor:pointer;
  background:linear-gradient(135deg,var(--brand),var(--brand2));margin-top:8px}

/* foco (teclado/controle) */
.focusable{outline:none}
.focused{box-shadow:0 0 0 3px var(--brand2);border-radius:10px}

/* Home estilo Netflix */
.nf-header{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:30px;padding:16px 40px;
  background:linear-gradient(180deg,#0a0f1c 65%,rgba(10,15,28,0))}
.nf-brand{font-size:26px;font-weight:900;color:var(--brand2);letter-spacing:1px;text-transform:uppercase}
.nf-menu{display:flex;gap:24px;align-items:center;flex-wrap:wrap}
.nf-nav{color:#cfd6e6;font-size:16px;cursor:pointer;padding:6px 2px;white-space:nowrap}
.nf-nav:hover{color:#fff}
.nf-nav.active{color:#fff;font-weight:700;border-bottom:3px solid var(--brand)}
.nf-nav.focused{color:#fff;text-shadow:0 0 10px var(--brand2)}
.nf-content{height:calc(100vh - 72px);overflow-y:auto;padding:6px 0 60px}
.nf-row{margin:24px 0}
.nf-row h3{font-size:20px;font-weight:700;margin:0 40px 12px;color:#e6ecff}
.nf-cards{display:flex;gap:12px;overflow-x:auto;padding:8px 40px;scroll-snap-type:x proximity}
.nf-grid{display:flex;flex-wrap:wrap;gap:14px;padding:10px 40px}
.nf-skel{color:var(--muted);padding:34px 6px;font-size:14px}
.poster{position:relative;flex:0 0 auto;width:155px;aspect-ratio:2/3;border-radius:8px;overflow:hidden;
  background:var(--surf2);cursor:pointer;scroll-snap-align:start;transition:transform .15s,box-shadow .15s}
.poster img{width:100%;height:100%;object-fit:cover;display:block}
.poster .pt{position:absolute;left:0;right:0;bottom:0;padding:22px 8px 7px;font-size:12px;color:#fff;
  background:linear-gradient(0deg,rgba(0,0,0,.9),transparent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.poster:hover,.poster.focused{transform:scale(1.09);box-shadow:0 10px 28px rgba(0,0,0,.65),0 0 0 2px var(--brand2);z-index:3}
.poster.ch{width:215px;aspect-ratio:16/9;background:#0d1424}
.poster.ch img{object-fit:contain;padding:16px}
.empty{text-align:center;color:var(--muted);padding:50px;font-size:16px}
/* barras de rolagem visíveis */
.nf-content::-webkit-scrollbar,.nf-cards::-webkit-scrollbar{width:12px;height:10px}
.nf-content::-webkit-scrollbar-thumb,.nf-cards::-webkit-scrollbar-thumb{background:#2a3a5e;border-radius:8px;border:2px solid var(--bg)}
.nf-content::-webkit-scrollbar-thumb:hover,.nf-cards::-webkit-scrollbar-thumb:hover{background:var(--brand)}
.nf-content,.nf-cards{scrollbar-width:thin;scrollbar-color:#2a3a5e transparent}
/* busca */
.nf-search{margin-left:auto;width:250px;max-width:34vw;padding:9px 14px;border-radius:8px;border:1px solid #2a3a5e;background:#0d1424;color:#fff;font-size:14px}
.nf-search:focus{outline:none;border-color:var(--brand)}
/* banner hero estilo Netflix */
.nf-hero{position:relative;height:44vh;min-height:300px;margin-bottom:4px;background-size:cover;background-position:center 20%;display:flex;align-items:flex-end}
.hero-grad{position:absolute;inset:0;background:linear-gradient(0deg,var(--bg) 5%,transparent 55%),linear-gradient(90deg,rgba(10,15,28,.9) 0%,rgba(10,15,28,.2) 55%,transparent 75%)}
.hero-info{position:relative;z-index:2;padding:0 40px 28px}
.hero-title{font-size:40px;font-weight:900;color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.75);max-width:62%;line-height:1.1}
.hero-btn{margin-top:18px;background:#fff;color:#111;border:none;border-radius:6px;padding:12px 32px;font-size:18px;font-weight:800;cursor:pointer}
.hero-btn:hover,.hero-btn.focused{background:var(--brand);color:#fff;box-shadow:0 0 0 3px var(--brand2)}
.hero-plot{color:#cfd6e6;font-size:14px;line-height:1.45;max-width:55%;max-height:4.3em;overflow:hidden;margin-top:10px;text-shadow:0 1px 6px rgba(0,0,0,.7)}
/* detalhe da série (Netflix — 2 colunas) */
.sd2{position:relative;display:flex;height:calc(100vh - 72px);background-size:cover;background-position:center}
.sd2-ov{position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,12,22,.98) 0%,rgba(8,12,22,.93) 34%,rgba(8,12,22,.7) 100%)}
.sd2-left{position:relative;z-index:2;width:360px;min-width:300px;padding:34px 28px;overflow-y:auto}
.sd2-title{font-size:34px;font-weight:900;line-height:1.05}
.sd2-meta{color:#9fb0cf;font-size:14px;margin:10px 0 14px}
.sd2-plot{color:#cfd6e6;font-size:14px;line-height:1.5;margin-bottom:20px;max-height:10em;overflow:hidden}
.sd2-seasons{display:flex;flex-direction:column;gap:8px}
.sd2-season{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:13px 15px;border-radius:8px;background:rgba(255,255,255,.06);color:#cfd6e6;font-size:15px;cursor:pointer}
.sd2-season b{color:#7b86a0;font-size:12px;font-weight:600}
.sd2-season:hover,.sd2-season.focused{background:rgba(255,255,255,.16);color:#fff}
.sd2-season.active{background:var(--brand);color:#fff;font-weight:700}.sd2-season.active b{color:#dfffe9}
.sd2-right{position:relative;z-index:2;flex:1;min-width:0;overflow-y:auto;padding:22px 32px 60px}
.ep{display:flex;align-items:center;gap:16px;padding:14px;border-radius:10px;cursor:pointer;border-bottom:1px solid #1a2440}
.ep:hover,.ep.focused{background:rgba(255,255,255,.06)}
.ep-thumb{position:relative;width:160px;height:90px;flex:0 0 auto;border-radius:8px;overflow:hidden;background:#1e2a4a}
.ep-thumb img{width:100%;height:100%;object-fit:cover}
.ep-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff;opacity:0;background:rgba(0,0,0,.4);transition:opacity .12s}
.ep:hover .ep-play,.ep.focused .ep-play{opacity:1}
.ep-body{flex:1;min-width:0}
.ep-title{font-size:16px;font-weight:600;color:#fff}
.ep-plot{font-size:13px;color:#9fb0cf;margin-top:4px;max-height:3em;overflow:hidden}
.ep-dur{color:#7b86a0;font-size:13px;flex:0 0 auto}
/* EPG no player */
.epg-now{position:fixed;left:18px;bottom:70px;z-index:102;max-width:70vw;background:rgba(0,0,0,.7);color:#fff;
  padding:10px 16px;border-radius:8px;font-size:15px;display:none}

.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.88);
  padding:14px 26px;border-radius:10px;font-size:16px;display:none;z-index:200;max-width:90vw;text-align:center}
.spin{padding:40px;text-align:center;color:var(--muted);font-size:18px}

/* Mobile */
@media (max-width:720px){
  .nf-header{flex-wrap:wrap;gap:12px;padding:12px 16px}
  .nf-brand{font-size:20px}
  .nf-menu{gap:16px;order:2}
  .nf-search{order:3;width:100%;max-width:none;margin-left:0}
  .nf-content{height:calc(100vh - 130px)}
  .nf-row h3,.nf-cards,.nf-grid{padding-left:16px;padding-right:16px;margin-left:0;margin-right:0}
  .nf-row h3{margin-left:16px}
  .poster{width:115px}.poster.ch{width:160px}
  .nf-hero{height:34vh;min-height:200px}
  .hero-title{font-size:24px;max-width:90%}
  .hero-plot{max-width:92%;font-size:13px}
  .hero-btn{font-size:15px;padding:10px 22px}
  .sd2{flex-direction:column;height:auto}
  .sd2-left{width:100%;min-width:0;padding:18px 16px;overflow:visible}
  .sd2-title{font-size:24px}.sd2-plot{max-height:6em}
  .sd2-right{padding:10px 16px 50px;height:auto;overflow:visible}
  .ep{gap:10px;padding:10px 6px}
  .ep-thumb{width:120px;height:68px}.ep-title{font-size:14px}.ep-plot{display:none}
  .macbox .mac{font-size:26px}
}
