/* ==========================================================
   NEXFLIX — Home (layout + coverflow + categorias)
   ========================================================== */

:root{
  --brand:#e50914;--text:#fff;--muted:#c8c8c8;
  --gap-after-slider: clamp(28px, 6.2vw, 80px);
  --gap-title-to-slider: clamp(8px, 2.2vw, 18px);
}

html,body{background:#000;color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;margin:0}
.container{max-width:1300px;margin:0 auto;padding:0 16px}

/* Header fixo */
header.site-header{position:sticky;top:0;z-index:9999;background:rgba(0,0,0,.65);backdrop-filter:blur(6px);border-bottom:1px solid rgba(255,255,255,.06)}
.header-row{display:flex;justify-content:space-between;align-items:center;height:60px}
.brand{font-weight:900;letter-spacing:2px;text-decoration:none;font-size:22px;color:#fff}
.brand::first-letter{color:var(--brand)}
.nav a{color:#ddd;text-decoration:none;margin:0 10px}
.nav a:hover{color:#fff}

/* ==========================================================
   Coverflow base (com anti-flicker e performance)
   ========================================================== */
.cflow-root{
  position:relative;overflow:hidden;
  /* ↓ marge ns laterais intactas, topo/fundo bem menores para compactar */
  margin: clamp(8px, 2vw, 14px) 0;
}
/* primeiro slider ainda mais próximo do bloco anterior (search) */
.cflow-root:first-of-type{ margin-top: clamp(6px, 1.8vw, 12px); }

.cflow-stage{
  position:relative;perspective:1200px;width:100%;
  height:var(--cf-h,520px);margin:0 auto;max-width:1300px;
  contain: layout paint size style;
}
.cflow-deck{
  position:absolute;inset:0;transform-style:preserve-3d;
  will-change: transform;
  visibility:visible;
}
.cflow-card{
  position:absolute;top:50%;left:50%;
  transform: translate(-50%,-50%);transform-style:preserve-3d;
  border-radius:16px; overflow:hidden;background:#000;
  box-shadow:0 18px 40px rgba(0,0,0,.45);cursor:pointer; user-select:none; -webkit-tap-highlight-color:transparent;
  backface-visibility:hidden;
  will-change: transform;
  transition:
    transform .8s cubic-bezier(.22,.7,.22,1),
    box-shadow .4s linear,
    opacity .28s ease;
}

/* Dimensão “segura” por tipo (sem depender da imagem) */
.cflow-card[data-kind="backdrop"]{
  width: min(92vw, 1100px);
  aspect-ratio: 16 / 9;
}
.cflow-card[data-kind="poster"]{
  width: min(34vw, 260px);
  aspect-ratio: 2 / 3;
}

/* Imagens cobrem a carta inteira */
.cflow-card img{
  display:block;width:100%;height:100%;
  object-fit: cover;
  object-position:center;background:#000;position:relative; z-index:1;
  pointer-events:none;
}

.cflow-card.active{box-shadow:0 28px 60px rgba(0,0,0,.6)}

/* Legenda */
.cflow-caption{
  position:absolute;left:12px;right:12px;bottom:18px;padding:8px 12px;border-radius:12px;
  color:#fff;font-weight:800;background:linear-gradient(90deg,rgba(0,0,0,.72),rgba(0,0,0,.38));backdrop-filter:blur(4px);
  opacity:0;transform:translateY(6px);transition:.35s ease;z-index:2;text-shadow:0 2px 8px rgba(0,0,0,.55);
}
.cflow-card.active .cflow-caption{opacity:1;transform:translateY(0)}
.cflow-title{font-size:clamp(16px,3vw,22px)}
.cflow-note{opacity:.95}
.card-link{position:absolute;inset:0;display:block}

/* Nav */
.cflow-nav{position:absolute;inset:0;pointer-events:none}
.cflow-arrow{
  position:absolute;top:50%;transform:translateY(-50%);pointer-events:auto;
  background:rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.18);
  width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:4;color:#fff
}
.cflow-prev{left:10px}.cflow-next{right:10px}
.cflow-dots{position:absolute;left:0;right:0;bottom:12px;display:flex;gap:8px;justify-content:center;z-index:4}
.cflow-dot{width:8px;height:8px;border-radius:50%;background:#777;opacity:.6;transition:opacity .2s ease,transform .2s ease}
.cflow-dot.active{background:#fff;opacity:1;transform:scale(1.1)}

/* Presets de altura */
.cf-hero  { --cf-h: clamp(380px,62vh,520px); }
.cf-high  { --cf-h: 320px; }
.cf-poster{ --cf-h: 320px; }

/* Cabeçalhos com faixa */
.section-head{margin:12px 0}
.section-head .container{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.title-strap{
  --strap-pad-y:.55em; --strap-pad-x:1.05em; --strap-radius:999px;
  --strap-bg: linear-gradient(90deg, rgba(229,9,20,.55), rgba(255,255,255,.18) 60%, rgba(255,255,255,0));
  position:relative; display:inline-block; margin:0;
  padding: var(--strap-pad-y) var(--strap-pad-x);
  font-size: clamp(18px, 2.8vw, 30px);
  line-height: 1.15; font-weight: 900; letter-spacing:.2px; z-index:0;
}
.title-strap::before{
  content:""; position:absolute; top:0; bottom:0;
  left: calc(-0.9 * var(--strap-pad-x)); right: calc(-0.9 * var(--strap-pad-x));
  border-radius: var(--strap-radius); background: var(--strap-bg); z-index:-1; filter: blur(.2px);
}
.more{font-size:14px;text-decoration:none;color:#fff;opacity:.85;white-space:nowrap}
.more:hover{opacity:1}

/* Espaços */
.cflow-root + .section-head{ margin-top: var(--gap-after-slider); }
.section-head + .cflow-root{ margin-top: var(--gap-title-to-slider); }

/* ==========================================================
   Barra de Categorias
   ========================================================== */
.catbar{
  background:linear-gradient(180deg,#12030d,#0b0009);
  padding:10px 0; /* compacto */
  border-bottom:1px solid rgba(255,255,255,.06);
  /* ↓ desce um pouco após o header e dá espaço controlado até o search */
  margin-top: clamp(8px, 1.8vw, 18px);
  margin-bottom: clamp(14px, 3vw, 26px);
}
.catbar .container{max-width:1300px;margin:0 auto;padding:0 16px}
.catbar h3{margin:0 0 10px;font-size:14px;letter-spacing:.18em;color:#cfc2cc;opacity:.9}
.catrail{position:relative}
.catrail-track{display:flex;gap:10px;overflow:auto;scroll-snap-type:x mandatory;padding:6px 40px 8px}
.catrail-track::-webkit-scrollbar{height:10px}
.catrail-track::-webkit-scrollbar-thumb{background:rgba(255,255,255,.14);border-radius:999px}
.catpill{
  scroll-snap-align:center;display:inline-flex;align-items:center;justify-content:center;
  padding:10px 16px;border-radius:999px;border:1px solid rgba(255,255,255,.14);
  background:#1a1418;color:#fff;text-decoration:none;font-weight:800;font-size:13px;letter-spacing:.3px;white-space:nowrap;opacity:.95;
  transition:transform .08s ease, filter .2s ease, background .2s ease;
}
.catpill:hover{filter:brightness(1.1)}
.catnav{
  position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.45);color:#fff;cursor:pointer
}
.catnav.prev{left:0}.catnav.next{right:0}

/* Sem transição (primeiro paint / resize) */
.cflow-deck.no-trans .cflow-card,
.no-trans .cflow-card{ transition: none !important; }

/* Responsivo */
@media (max-width:768px){
  :root{ --gap-after-slider: clamp(32px, 9vw, 96px); --gap-title-to-slider: clamp(10px, 3vw, 20px); }
  .cf-hero{--cf-h:360px}.cf-high{--cf-h:280px}.cf-poster{--cf-h:280px}
  .cflow-arrow{display:none}.cflow-caption{padding:6px 8px}
  .catnav{display:none}
}
@media (min-width: 1024px){
  .cf-hero .cflow-caption{ bottom: clamp(28px, 5.2vh, 88px); }
}

/* Rodapé */
footer.site-footer{border-top:1px solid rgba(255,255,255,.06);margin-top:26px}
footer .container{display:flex;align-items:center;justify-content:center;height:60px;color:#aaa}

/* ===== Full-bleed util ===== */
.full-bleed{
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  width: 100vw;
}

/* ===== Hero full-bleed ===== */
.cf-hero{
  --cf-h: clamp(420px, 70vh, 760px);
}
.cf-hero .cflow-stage{
  max-width: none;
  width: 100vw;
}
.cf-hero .cflow-deck{ visibility: visible; }
.cflow-card[data-kind="backdrop"]{
  width: min(96vw, 1600px);
  aspect-ratio: 16 / 9;
}
.cflow-card img{ object-fit: cover; object-position: center; }

/* evita scroll horizontal */
html, body{ overflow-x: hidden; }

/* ==========================================================
   Torofilm-like Search (pill + botão redondo)
   - aplica nas classes .tor-search e .nx-searchbar
   ========================================================== */
.tor-search,
.nx-searchbar{
  max-width:760px;
  /* ↓ pequeno espaço do topo e distância RESPONSIVA até o 1º slider */
  margin: clamp(4px, 1.4vw, 10px) auto clamp(16px, 3.2vw, 28px);
  padding:0 12px
}
.tor-search form,
.nx-searchbar form{
  display:flex;align-items:center;gap:0;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  border-radius:48px; overflow:hidden;
  box-shadow:0 8px 26px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.06);
  backdrop-filter:blur(6px);
}
.tor-search input,
.nx-searchbar input{
  flex:1; min-width:0;
  background:transparent; border:0; outline:none;
  color:#fff; font-size:1rem;
  padding:12px 18px;
}
.tor-search input::placeholder,
.nx-searchbar input::placeholder{color:#cfd2d6}
.tor-search button,
.nx-searchbar button{
  background:linear-gradient(135deg,#16d2ff,#0b74ff);
  border:0; margin:6px; padding:10px; /* fino */
  width:42px; height:42px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:#fff;
  transition:transform .15s ease, filter .2s ease, box-shadow .2s ease;
  box-shadow:0 6px 16px rgba(11,116,255,.35);
}
.tor-search button:hover,
.nx-searchbar button:hover{ filter:brightness(1.08); transform:translateY(-1px) }
.tor-search button:active,
.nx-searchbar button:active{ transform:translateY(0) scale(.98) }
.tor-search button svg,
.nx-searchbar button svg{width:20px;height:20px;fill:currentColor}

/* foco acessível */
.tor-search input:focus,
.nx-searchbar input:focus{ outline:2px solid rgba(13,202,240,.4); outline-offset:2px }
.tor-search button:focus-visible,
.nx-searchbar button:focus-visible{ outline:2px solid #16d2ff; outline-offset:2px }

/* --- resets essenciais p/ mobile (iOS/Android) --- */
.tor-search input,
.tor-search button,
.nx-searchbar input,
.nx-searchbar button{
  -webkit-appearance: none;
  appearance: none;
  background: transparent;
  border: 0;
  outline: 0;
}
.tor-search input::-webkit-search-cancel-button,
.nx-searchbar input::-webkit-search-cancel-button{ display:none }

/* ===== Responsivo ===== */
@media (max-width: 768px){
  .tor-search,.nx-searchbar{max-width: 92vw; margin: clamp(4px,1.6vw,8px) auto clamp(12px,3.6vw,22px)}
  .tor-search input,.nx-searchbar input{ padding:10px 14px; font-size:.95rem }
  .tor-search button,.nx-searchbar button{ width:38px; height:38px; padding:8px; margin:6px }
  .tor-search button svg,.nx-searchbar button svg{ width:18px; height:18px }
  .catbar{ margin-top: clamp(6px,2.2vw,14px); margin-bottom: clamp(12px,3.6vw,22px); }
}
@media (max-width: 420px){
  .tor-search,.nx-searchbar{padding:0 8px}
  .tor-search input,.nx-searchbar input{ padding:10px 12px; font-size:.92rem }
  .tor-search button,.nx-searchbar button{ width:36px; height:36px; padding:8px }
}

/* integra com as páginas */
.page-search .tor-search,
.page-search .nx-searchbar{ margin-top:14px }

/* ===== Ajustes relacionais para garantir proximidade com o 1º slider ===== */
/* Se logo após a barra de busca vier um título de seção, reduza o espaço dele */
.tor-search + .section-head,
.nx-searchbar + .section-head{ margin-top: clamp(8px, 2.2vw, 16px); }

/* Se a barra de busca vier direto antes do slider, reduza o topo do slider */
.tor-search + .cflow-root,
.nx-searchbar + .cflow-root{ margin-top: clamp(10px, 2.6vw, 18px); }

/* === Mobile spacing overrides (added by ChatGPT on 2025-09-20) === */

@media (max-width: 640px){
  /* Remove folgas extras acima/abaixo dos sliders no mobile */
  .cflow-root{ margin: 4px 0 !important; }
  .cf-hero .cflow-stage{ margin-top: 0 !important; }
}


/* === Mobile slider gap (revised) — 2025-09-20 === */
@media (max-width: 640px){
  .nx-searchbar + .cflow-root,
  .tor-search + .cflow-root,
  .cflow-root{ margin-top: 2px !important; }
}


/* === Mobile correction: spacing controlled from search, not slider === */
@media (max-width: 640px){
  .cflow-root:first-of-type{ margin-top: 0 !important; } /* cola no search */
  .tor-search{ margin-bottom: 6px !important; } /* controla espaçamento */
}


/* === Mobile: controle do gap pelo slider (hero) — 2025-09-20 === */
@media (max-width: 640px){
  .tor-search + .cflow-root.cf-hero{ margin-top: 0 !important; }
  .cf-hero .cflow-stage{ margin-top: 0 !important; padding-top: 0 !important; }
}


/* === Mobile: cola o HERO ao search mesmo com <main> intermediário — 2025-09-21 === */
@media (max-width: 640px){
  /* Quando houver <main> entre a barra e o hero */
  .tor-search + main > section.cflow-root.cf-hero{ margin-top: 0 !important; }
  .tor-search + * > section.cflow-root.cf-hero{ margin-top: 0 !important; }
  .tor-search ~ main > section.cflow-root.cf-hero{ margin-top: 0 !important; }
  /* Fallback: se o HERO for o primeiro bloco do <main> */
  main > section.cflow-root.cf-hero:first-of-type{ margin-top: 0 !important; }

  /* Mantém um respiro mínimo no search */
  .tor-search{ margin-bottom: 6px !important; }
}


/* === Mobile hero compact — 2025-09-21 === */
@media (max-width: 640px){
  /* Diminui a altura do deck do HERO para reduzir o "vazio" acima */
  .cf-hero .cflow-deck{ min-height: clamp(140px, 34vw, 260px) !important; }
}


/* === Mobile FIX (safe) — 2025-09-21 === */
@media (max-width: 640px){
  /* Cola o HERO ao search, mas sem alterar posicionamento interno */
  .tor-search + main > section.cflow-root.cf-hero,
  .tor-search + * > section.cflow-root.cf-hero,
  .tor-search ~ main > section.cflow-root.cf-hero,
  main > section.cflow-root.cf-hero:first-of-type{
    margin-top: 0 !important;
  }

  /* Espaçamento mínimo no search */
  .tor-search{ margin-bottom: 6px !important; }

  /* Altura moderada do deck do HERO para reduzir vazio, sem colapsar a área */
  .cf-hero .cflow-deck{
    min-height: clamp(160px, 42vw, 320px) !important;
  }
}


/* === Mobile SAFE SPACING — 2025-09-21 === */
@media (max-width: 640px){
  /* Controla o espaço entre search e hero sem reduzir altura do deck */
  .tor-search + main > section.cflow-root.cf-hero,
  main > section.cflow-root.cf-hero:first-of-type{
    margin-top: 4px !important;
  }
  .tor-search{ margin-bottom: 6px !important; }
}


/* === Mobile RESET (ultra safe) — 2025-09-21 === */
@media (max-width: 640px){
  /* NÃO cola, apenas aproxima: evita quebra de layout */
  .tor-search + main > section.cflow-root.cf-hero,
  .tor-search + * > section.cflow-root.cf-hero,
  .tor-search ~ main > section.cflow-root.cf-hero,
  main > section.cflow-root.cf-hero:first-of-type{
    margin-top: 6px !important; /* leve aproximação sem colar */
  }

  /* Mantém um respiro do search e padroniza altura interna */
  .tor-search{ margin-bottom: 8px !important; }

  /* Volta o deck do HERO a um valor seguro (similar ao original) */
  .cf-hero .cflow-deck{ min-height: clamp(180px, 36vw, 380px) !important; }
}


/* === Mobile minimal gap rule (v8) — ONLY outer spacing === */
@media (max-width: 640px){
  /* Keep a small, safe gap between search and first HERO */
  .tor-search + main > section.cflow-root.cf-hero,
  .tor-search ~ main > section.cflow-root.cf-hero,
  main > section.cflow-root.cf-hero:first-of-type{
    margin-top: 6px !important;
  }
  /* Small margin below the search (prevents overlap) */
  .tor-search{ margin-bottom: 6px !important; }
}
