/* ========================================
   IPTV IgrejaParaTi — Visual diferenciado
   Tema: Dark Neon + Glassmorphism + Grid
   ======================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Outfit','Space Grotesk',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:#05010f;
  color:#e9e6ff;
  line-height:1.65;
  overflow-x:hidden;
  min-height:100vh;
  position:relative;
  -webkit-font-smoothing:antialiased;
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:.25s}
ul{list-style:none}
:focus-visible{outline:2px solid #c084fc;outline-offset:3px;border-radius:6px}

/* ==== BACKGROUND ANIMADO ==== */
.bg-grid{
  position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    linear-gradient(180deg,#05010f 0%,#0a0118 50%,#05010f 100%),
    repeating-linear-gradient(90deg,rgba(168,85,247,.06) 0 1px,transparent 1px 80px),
    repeating-linear-gradient(0deg,rgba(168,85,247,.06) 0 1px,transparent 1px 80px);
  background-blend-mode:normal,screen,screen;
}
.bg-orbs{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.orb{
  position:absolute;border-radius:50%;filter:blur(80px);opacity:.55;
  animation:float 18s ease-in-out infinite;
}
.orb-1{width:520px;height:520px;background:#a855f7;top:-150px;left:-120px}
.orb-2{width:420px;height:420px;background:#06b6d4;bottom:-120px;right:-80px;animation-delay:-6s}
.orb-3{width:380px;height:380px;background:#ec4899;top:40%;left:55%;animation-delay:-12s;opacity:.35}
@keyframes float{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(40px,-30px) scale(1.05)}
  66%{transform:translate(-30px,40px) scale(.95)}
}

/* ==== HEADER ==== */
.site-header{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;gap:24px;
  padding:14px clamp(20px,5vw,60px);
  backdrop-filter:blur(18px) saturate(180%);
  -webkit-backdrop-filter:blur(18px) saturate(180%);
  background:rgba(10,1,24,.55);
  border-bottom:1px solid rgba(168,85,247,.18);
}
.logo{display:flex;align-items:center;gap:10px;font-weight:900;font-size:1.05rem;letter-spacing:.4px}
.logo-mark{
  background:linear-gradient(135deg,#a855f7,#06b6d4 60%,#ec4899);
  padding:6px 10px;border-radius:8px;color:#fff;font-size:.85rem;
  box-shadow:0 6px 25px rgba(168,85,247,.45);
}
.logo-text{color:#fff}
.main-nav{display:flex;gap:26px;margin-left:auto;font-size:.95rem;font-weight:500}
.main-nav a{color:#cfc6ff;position:relative}
.main-nav a:hover{color:#fff}
.main-nav a::after{
  content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;
  background:linear-gradient(90deg,#a855f7,#06b6d4);transition:.3s;
}
.main-nav a:hover::after{width:100%}
.cta{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:700;letter-spacing:.3px;
  padding:12px 22px;border-radius:999px;
  cursor:pointer;border:0;font-family:inherit;
  transition:transform .25s,box-shadow .25s,filter .25s;
  white-space:nowrap;
}
.cta-header{padding:10px 18px;font-size:.9rem;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;box-shadow:0 8px 28px rgba(168,85,247,.45)}
.cta-primary{background:linear-gradient(135deg,#a855f7 0%,#ec4899 60%,#f59e0b 120%);color:#fff;box-shadow:0 12px 36px rgba(236,72,153,.45)}
.cta-primary:hover{transform:translateY(-3px);box-shadow:0 18px 50px rgba(236,72,153,.6);filter:brightness(1.08)}
.cta-ghost{background:rgba(255,255,255,.05);color:#fff;border:1px solid rgba(168,85,247,.5)}
.cta-ghost:hover{background:rgba(168,85,247,.15);transform:translateY(-3px)}
.cta-soft{background:rgba(168,85,247,.12);color:#e9e6ff;border:1px solid rgba(168,85,247,.4)}
.cta-soft:hover{background:rgba(168,85,247,.25)}
.cta-big{padding:18px 36px;font-size:1.05rem}

/* ==== HERO ==== */
.hero{
  text-align:center;
  padding:90px clamp(20px,5vw,60px) 80px;
  max-width:1100px;margin:0 auto;
  position:relative;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px;border-radius:999px;font-size:.85rem;
  background:rgba(6,182,212,.08);
  border:1px solid rgba(6,182,212,.4);
  color:#7dd3fc;font-weight:500;
  margin-bottom:28px;
}
.pulse{
  width:8px;height:8px;border-radius:50%;background:#22c55e;
  box-shadow:0 0 0 0 rgba(34,197,94,.7);
  animation:pulse 1.8s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(34,197,94,.7)}
  70%{box-shadow:0 0 0 14px rgba(34,197,94,0)}
  100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}
}
.hero-title{
  font-size:clamp(2.4rem,6vw,4.6rem);
  font-weight:900;line-height:1.05;letter-spacing:-.02em;
  margin-bottom:24px;
}
.grad{
  background:linear-gradient(135deg,#c084fc 0%,#ec4899 50%,#f59e0b 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.grad-2{
  background:linear-gradient(135deg,#06b6d4,#a855f7);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-sub{
  font-size:clamp(1.05rem,2vw,1.25rem);
  color:#bbb3e6;max-width:780px;margin:0 auto 36px;
}
.hero-sub strong{color:#fff;font-weight:600}
.hero-ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:60px}
.hero-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  max-width:780px;margin:0 auto;
  padding:24px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(168,85,247,.18);
  border-radius:20px;
  backdrop-filter:blur(10px);
}
.hero-stats li{text-align:center;display:flex;flex-direction:column;gap:4px}
.hero-stats strong{
  font-size:clamp(1.2rem,2.5vw,1.7rem);font-weight:800;
  background:linear-gradient(135deg,#c084fc,#06b6d4);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-stats span{font-size:.82rem;color:#a59bd9;text-transform:uppercase;letter-spacing:.5px}

/* ==== BLOCK GENÉRICO ==== */
.block{
  padding:90px clamp(20px,5vw,60px);
  max-width:1240px;margin:0 auto;
}
.block.alt{
  position:relative;
  isolation:isolate;
}
.block.alt::before{
  content:"";
  position:absolute;
  z-index:-1;
  top:0;bottom:0;
  left:50%;transform:translateX(-50%);
  width:100vw;
  background:
    linear-gradient(180deg,transparent,rgba(168,85,247,.05) 30%,rgba(168,85,247,.05) 70%,transparent),
    radial-gradient(ellipse at top,rgba(6,182,212,.08),transparent 60%);
  pointer-events:none;
}
.kicker{
  display:inline-block;font-size:.78rem;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  color:#c084fc;margin-bottom:14px;
  padding:6px 14px;border:1px solid rgba(192,132,252,.3);
  border-radius:999px;background:rgba(192,132,252,.06);
}
.block h2{
  font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;
  letter-spacing:-.01em;line-height:1.15;margin-bottom:18px;color:#fff;
  max-width:900px;
}
.block-sub{font-size:1.05rem;color:#bbb3e6;max-width:780px;margin-bottom:50px}
.block-sub strong{color:#fff}

/* ==== TWO COL ==== */
.two-col{display:grid;grid-template-columns:1.2fr 1fr;gap:50px;align-items:start;margin-top:40px}
.two-col p{margin-bottom:18px;color:#cfc6ff}
.two-col strong{color:#fff;font-weight:600}
.card-iptv{
  padding:32px;border-radius:24px;
  background:linear-gradient(160deg,rgba(168,85,247,.12),rgba(6,182,212,.06));
  border:1px solid rgba(168,85,247,.3);
  backdrop-filter:blur(12px);
  position:relative;overflow:hidden;
}
.card-iptv::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at top right,rgba(236,72,153,.25),transparent 50%);
  pointer-events:none;
}
.card-iptv h3{font-size:1.3rem;margin-bottom:18px;color:#fff;position:relative}
.check-list{position:relative;display:flex;flex-direction:column;gap:12px}
.check-list li{
  padding-left:32px;position:relative;color:#e2dcff;font-size:.98rem;
}
.check-list li::before{
  content:"✓";position:absolute;left:0;top:0;
  width:22px;height:22px;border-radius:50%;
  background:linear-gradient(135deg,#22c55e,#06b6d4);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:.75rem;font-weight:900;
}

/* ==== FEATURES ==== */
.grid-feat{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:20px;margin-top:40px;
}
.feat{
  padding:28px 24px;border-radius:20px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(168,85,247,.15);
  transition:.3s;position:relative;overflow:hidden;
}
.feat::after{
  content:"";position:absolute;top:0;left:0;width:100%;height:2px;
  background:linear-gradient(90deg,#a855f7,#06b6d4,#ec4899);
  transform:scaleX(0);transform-origin:left;transition:.4s;
}
.feat:hover{transform:translateY(-6px);background:rgba(168,85,247,.08);border-color:rgba(168,85,247,.4)}
.feat:hover::after{transform:scaleX(1)}
.feat-icon{
  font-size:2.2rem;margin-bottom:14px;
  width:60px;height:60px;border-radius:16px;
  background:linear-gradient(135deg,rgba(168,85,247,.2),rgba(6,182,212,.15));
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(168,85,247,.3);
}
.feat h3{font-size:1.15rem;margin-bottom:8px;color:#fff;font-weight:700}
.feat p{color:#b8aedf;font-size:.94rem;line-height:1.6}

/* ==== PLANOS ==== */
.plans{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:22px;margin-top:50px;
}
.plan{
  padding:32px 26px;border-radius:24px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(168,85,247,.2);
  display:flex;flex-direction:column;gap:18px;
  position:relative;transition:.3s;
}
.plan:hover{transform:translateY(-6px);border-color:rgba(168,85,247,.5)}
.plan.featured{
  background:linear-gradient(160deg,rgba(168,85,247,.18),rgba(236,72,153,.12));
  border:1.5px solid #a855f7;
  box-shadow:0 20px 60px rgba(168,85,247,.35);
}
.plan.featured:hover{transform:translateY(-8px)}
.plan-badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,#ec4899,#f59e0b);
  color:#fff;font-size:.72rem;font-weight:800;letter-spacing:1px;
  padding:6px 14px;border-radius:999px;text-transform:uppercase;
}
.plan-head h3{font-size:1.3rem;font-weight:800;color:#fff;margin-bottom:4px}
.plan-tag{color:#c084fc;font-size:.85rem;font-weight:500}
.plan-price{
  font-size:2.8rem;font-weight:900;color:#fff;line-height:1;
  display:flex;align-items:baseline;gap:4px;
}
.plan-price span{font-size:1rem;color:#a59bd9;font-weight:600}
.plan-price small{font-size:.95rem;color:#a59bd9;font-weight:500}
.plan ul{display:flex;flex-direction:column;gap:10px;flex:1}
.plan ul li{
  padding-left:24px;position:relative;color:#cfc6ff;font-size:.92rem;
}
.plan ul li::before{
  content:"▸";position:absolute;left:0;color:#c084fc;font-weight:900;
}
.plan .cta{margin-top:8px;width:100%}

/* ==== TESTE ==== */
.teste{padding:90px clamp(20px,5vw,60px)}
.teste-card{
  max-width:900px;margin:0 auto;text-align:center;
  padding:60px 40px;border-radius:32px;
  background:
    linear-gradient(135deg,rgba(168,85,247,.18),rgba(236,72,153,.12) 50%,rgba(245,158,11,.1)),
    rgba(10,1,24,.6);
  border:1px solid rgba(236,72,153,.4);
  backdrop-filter:blur(20px);
  position:relative;overflow:hidden;
}
.teste-card::before{
  content:"";position:absolute;inset:-2px;border-radius:32px;
  background:linear-gradient(135deg,#a855f7,#ec4899,#f59e0b,#06b6d4);
  z-index:-1;opacity:.5;filter:blur(20px);
}
.teste-card h2{margin:0 auto 22px;color:#fff}
.teste-card p{color:#e2dcff;font-size:1.08rem;margin-bottom:32px;max-width:680px;margin-left:auto;margin-right:auto}
.teste-card p strong{color:#fff}
.teste-note{display:block;margin-top:18px;color:#a59bd9;font-size:.85rem}

/* ==== DEVICES ==== */
.devices{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:18px;margin-top:40px;
}
.dev{
  padding:24px;border-radius:18px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(6,182,212,.2);
  transition:.3s;
}
.dev:hover{background:rgba(6,182,212,.08);border-color:rgba(6,182,212,.5);transform:translateY(-4px)}
.dev span{font-size:2rem;display:block;margin-bottom:10px}
.dev h3{font-size:1.05rem;color:#fff;margin-bottom:6px;font-weight:700}
.dev p{color:#a59bd9;font-size:.88rem}

/* ==== TABELA COMPARATIVA ==== */
.table-wrap{overflow-x:auto;margin-top:40px;border-radius:20px;border:1px solid rgba(168,85,247,.2)}
.cmp{width:100%;border-collapse:collapse;background:rgba(255,255,255,.02);min-width:600px}
.cmp th,.cmp td{padding:16px 20px;text-align:left;border-bottom:1px solid rgba(168,85,247,.1)}
.cmp th{background:rgba(168,85,247,.1);color:#fff;font-weight:700;font-size:.92rem;letter-spacing:.3px}
.cmp td{color:#cfc6ff;font-size:.94rem}
.cmp td:nth-child(2){color:#86efac;font-weight:600}
.cmp td:nth-child(3){color:#fca5a5}
.cmp tbody tr:hover{background:rgba(168,85,247,.05)}

/* ==== REVIEWS ==== */
.reviews{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:20px;margin-top:40px;
}
.reviews blockquote{
  padding:28px;border-radius:20px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(168,85,247,.2);
  position:relative;
}
.reviews blockquote::before{
  content:"\201C";position:absolute;top:-10px;left:20px;
  font-size:5rem;color:#a855f7;opacity:.4;line-height:1;font-family:Georgia,serif;
}
.reviews p{color:#e2dcff;font-style:italic;margin-bottom:14px;line-height:1.6}
.reviews cite{font-style:normal;color:#c084fc;font-size:.85rem;font-weight:600}

/* ==== FAQ ==== */
.faq{display:flex;flex-direction:column;gap:12px;margin-top:40px;max-width:900px}
.faq details{
  padding:20px 24px;border-radius:16px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(168,85,247,.2);
  transition:.25s;
}
.faq details:hover{border-color:rgba(168,85,247,.4)}
.faq details[open]{background:rgba(168,85,247,.08);border-color:rgba(168,85,247,.5)}
.faq summary{
  cursor:pointer;font-weight:700;color:#fff;font-size:1.02rem;
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  list-style:none;
}
.faq summary::after{
  content:"+";font-size:1.5rem;color:#c084fc;transition:.25s;font-weight:300;
}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq summary::-webkit-details-marker{display:none}
.faq p{margin-top:14px;color:#cfc6ff;font-size:.96rem}

/* ==== FINAL ==== */
.final{
  text-align:center;padding:100px clamp(20px,5vw,60px);
}
.final h2{margin:0 auto 18px;background:linear-gradient(135deg,#c084fc,#ec4899);-webkit-background-clip:text;background-clip:text;color:transparent}
.final p{color:#bbb3e6;font-size:1.1rem;margin-bottom:32px}

/* ==== FOOTER ==== */
.site-footer{
  margin-top:60px;
  padding:60px clamp(20px,5vw,60px) 30px;
  background:linear-gradient(180deg,transparent,rgba(168,85,247,.06));
  border-top:1px solid rgba(168,85,247,.2);
}
.foot-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1.4fr;gap:40px;
  max-width:1240px;margin:0 auto;
}
.foot-grid > div p:not(.logo){color:#a59bd9;font-size:.9rem;margin-top:12px}
.foot-grid h4{color:#fff;margin-bottom:14px;font-size:1rem;font-weight:700}
.foot-grid ul{display:flex;flex-direction:column;gap:8px}
.foot-grid ul a{color:#cfc6ff;font-size:.9rem}
.foot-grid ul a:hover{color:#c084fc}
.tags{display:flex;flex-wrap:wrap;gap:6px}
.tags span{
  padding:4px 10px;border-radius:999px;font-size:.72rem;
  background:rgba(168,85,247,.1);border:1px solid rgba(168,85,247,.25);
  color:#cfc6ff;
}
.foot-bottom{
  max-width:1240px;margin:40px auto 0;padding-top:24px;
  border-top:1px solid rgba(168,85,247,.15);text-align:center;
}
.foot-bottom small{color:#7d76a8;font-size:.82rem}

/* ==== RESPONSIVE ==== */
@media (max-width:900px){
  .main-nav{display:none}
  .two-col{grid-template-columns:1fr;gap:30px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
  .plan.featured{transform:none}
  .plan.featured:hover{transform:translateY(-6px)}
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .teste-card{padding:40px 24px}
}
@media (max-width:560px){
  .site-header{padding:12px 16px;gap:12px}
  .cta-header{padding:8px 14px;font-size:.82rem}
  .logo-text{display:none}
  .hero{padding:60px 18px 50px}
  .hero-stats{grid-template-columns:repeat(2,1fr);padding:18px}
  .foot-grid{grid-template-columns:1fr}
  .block{padding:60px 18px}
  .teste-card{padding:36px 20px}
  .cta-big{padding:16px 28px;font-size:.98rem}
}

/* ==== REDUCED MOTION ==== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001s!important;transition-duration:.001s!important}
  .orb{animation:none}
  html{scroll-behavior:auto}
}

/* ==========================================================
   AJUSTES DE ALINHAMENTO + SEÇÃO PLAYERS IPTV
   ========================================================== */

/* HEADER — alinhamento perfeito em todas as larguras */
.site-header{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
}
.site-header .main-nav{
  margin-left:0;
  justify-self:center;
}
.site-header .logo{justify-self:start}
.site-header .cta-header{justify-self:end}

/* HERO — block centralizado (flex column quebrava largura dos filhos) */
.hero{
  display:block;
  text-align:center;
}
.hero-title{max-width:920px;margin-left:auto;margin-right:auto}
.hero-sub{max-width:760px;margin-left:auto;margin-right:auto;margin-bottom:36px}

/* PLANOS — grid já trata altura via align-items:stretch (default) */
.plan{justify-content:flex-start}
.plan ul{flex-grow:1}

/* FAQ — largura travada e centralizada */
.faq{margin-left:auto;margin-right:auto}

/* DEPOIMENTOS — altura uniforme dentro do grid */
.reviews{align-items:stretch}
.reviews blockquote{display:flex;flex-direction:column;justify-content:space-between;height:100%}

/* TESTE-CARD — corrige z-index do glow externo */
.teste-card{isolation:isolate;z-index:1}
.teste-card::before{z-index:-1}

/* TABELA — não estoura container */
.table-wrap{max-width:100%}

/* ==== SEÇÃO PLAYERS IPTV ==== */
.players{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:22px;
  margin-top:50px;
  align-items:stretch;
}
.player-card{
  display:flex;flex-direction:column;gap:14px;
  padding:30px 26px;border-radius:22px;
  background:linear-gradient(160deg,rgba(255,255,255,.04),rgba(168,85,247,.05));
  border:1px solid rgba(168,85,247,.2);
  transition:.3s;position:relative;overflow:hidden;
}
.player-card::after{
  content:"";position:absolute;top:0;left:0;width:100%;height:3px;
  background:linear-gradient(90deg,#a855f7,#06b6d4,#ec4899,#f59e0b);
  transform:scaleX(0);transform-origin:left;transition:.4s;
}
.player-card:hover{
  transform:translateY(-6px);
  border-color:rgba(168,85,247,.5);
  background:linear-gradient(160deg,rgba(168,85,247,.12),rgba(6,182,212,.08));
}
.player-card:hover::after{transform:scaleX(1)}
.player-logo{
  width:62px;height:62px;border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:1.05rem;color:#fff;letter-spacing:.5px;
  box-shadow:0 8px 24px rgba(0,0,0,.3);
  border:1px solid rgba(255,255,255,.12);
}
.player-xciptv{background:linear-gradient(135deg,#f97316,#ef4444)}
.player-smarters{background:linear-gradient(135deg,#3b82f6,#06b6d4)}
.player-ssiptv{background:linear-gradient(135deg,#10b981,#22d3ee)}
.player-duplecast{background:linear-gradient(135deg,#a855f7,#ec4899)}

.player-card h3{
  font-size:1.2rem;color:#fff;font-weight:800;line-height:1.25;
}
.player-card > p{
  color:#bbb3e6;font-size:.94rem;line-height:1.6;
}
.player-card > p strong{color:#fff;font-weight:600}

.player-tags{
  display:flex;flex-direction:column;gap:8px;
  padding:12px 14px;border-radius:12px;
  background:rgba(0,0,0,.18);
  border:1px solid rgba(168,85,247,.12);
  margin-top:auto;
}
.player-tags li{
  font-size:.82rem;color:#cfc6ff;padding-left:18px;position:relative;
}
.player-tags li::before{
  content:"●";position:absolute;left:0;top:0;color:#c084fc;font-size:.6rem;line-height:1.6;
}

.player-card .cta{margin-top:6px;width:100%;text-align:center}

.players-foot{
  margin-top:36px;text-align:center;
  color:#a59bd9;font-size:.92rem;line-height:1.7;
  max-width:900px;margin-left:auto;margin-right:auto;
  padding:20px 24px;border-radius:14px;
  background:rgba(255,255,255,.02);
  border:1px dashed rgba(168,85,247,.25);
}
.players-foot strong{color:#c084fc;font-weight:600}

/* HEADER em telas médias (esconde nav, mantém logo + cta) */
@media (max-width:1080px){
  .site-header .main-nav{gap:18px;font-size:.88rem}
}
@media (max-width:900px){
  .site-header{grid-template-columns:auto 1fr auto;gap:14px}
  .site-header .main-nav{display:none}
}
@media (max-width:560px){
  .site-header{grid-template-columns:1fr auto;gap:10px}
  .site-header .cta-header{padding:8px 14px;font-size:.78rem}
  .player-card{padding:26px 22px}
  .hero-stats{padding:16px;gap:12px}
}

/* TESTE-CARD com glow externo bem-comportado */
.teste{position:relative}

/* ==== BOTÃO WHATSAPP FLUTUANTE GLOBAL (compacto) ==== */
.wa-float{
  position:fixed;
  right:20px;bottom:20px;
  z-index:9999;
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px 10px 12px;
  border-radius:999px;
  background:linear-gradient(135deg,#25d366,#128c7e);
  color:#fff;font-weight:600;font-size:.85rem;
  line-height:1;
  text-decoration:none;
  box-shadow:0 8px 24px rgba(37,211,102,.4),0 2px 8px rgba(0,0,0,.35);
  border:1.5px solid rgba(255,255,255,.18);
  transition:transform .2s,box-shadow .2s;
  font-family:'Outfit',system-ui,sans-serif;
  white-space:nowrap;
}
.wa-float:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(37,211,102,.55),0 4px 12px rgba(0,0,0,.4);
}
.wa-float svg{width:20px;height:20px;flex-shrink:0;display:block}
.wa-float .wa-pulse{
  position:absolute;inset:-4px;border-radius:999px;
  border:1.5px solid #25d366;
  animation:waPulse 2.2s ease-out infinite;
  pointer-events:none;
}
@keyframes waPulse{
  0%{transform:scale(.95);opacity:.6}
  100%{transform:scale(1.18);opacity:0}
}
@media (max-width:560px){
  .wa-float{
    right:14px;bottom:14px;
    padding:11px;
    border-radius:50%;
  }
  .wa-float .wa-label{display:none}
  .wa-float svg{width:22px;height:22px}
}

/* Garante que o gradient do final é visível */
.final h2{display:inline-block}

/* Tabela comparativa: scroll horizontal limpo no mobile */
@media (max-width:600px){
  .cmp{font-size:.85rem}
  .cmp th,.cmp td{padding:12px 14px}
}

/* ==== FORMULÁRIO TESTE IPTV ==== */
.form-teste{
  display:flex;flex-direction:column;gap:18px;
  max-width:560px;margin:32px auto 0;
  text-align:left;
}
.form-row{display:flex;flex-direction:column;gap:8px}
.form-row label{
  font-size:.82rem;font-weight:600;color:#cfc6ff;
  text-transform:uppercase;letter-spacing:.5px;
}
.form-row input,
.form-row select{
  padding:14px 18px;
  border-radius:12px;
  border:1.5px solid rgba(168,85,247,.3);
  background:rgba(0,0,0,.3);
  color:#fff;
  font-family:inherit;font-size:1rem;
  transition:.25s;
  -webkit-appearance:none;appearance:none;
}
.form-row select{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23c084fc'><path d='M8 11L3 6h10z'/></svg>");
  background-repeat:no-repeat;
  background-position:right 16px center;
  padding-right:42px;
}
.form-row input::placeholder{color:#7d76a8}
.form-row input:focus,
.form-row select:focus{
  outline:none;
  border-color:#c084fc;
  background:rgba(168,85,247,.08);
  box-shadow:0 0 0 4px rgba(168,85,247,.15);
}
.form-row select option{background:#1a0a30;color:#fff}
.form-note{
  display:block;
  text-align:center;
  color:#a59bd9;font-size:.82rem;
  margin-top:8px;
}

/* ==== 404 — visual diferenciado ==== */
.err-wrap{
  min-height:80vh;
  display:flex;align-items:center;justify-content:center;
  padding:60px 20px;
  text-align:center;
  position:relative;
}
.err-code{
  font-size:clamp(7rem,22vw,14rem);
  font-weight:900;line-height:.9;
  background:linear-gradient(135deg,#a855f7 0%,#ec4899 50%,#f59e0b 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  margin-bottom:20px;
  filter:drop-shadow(0 8px 40px rgba(168,85,247,.3));
}
.err-title{
  font-size:clamp(1.5rem,3.5vw,2.4rem);
  font-weight:800;color:#fff;margin-bottom:14px;
}
.err-sub{
  color:#bbb3e6;font-size:1.05rem;
  max-width:540px;margin:0 auto 32px;
}
.err-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:50px}
.err-links{
  max-width:600px;margin:0 auto;
  padding:24px;border-radius:18px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(168,85,247,.2);
}
.err-links h3{color:#c084fc;font-size:.85rem;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:14px}
.err-links ul{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:10px;
}
.err-links a{
  padding:10px 14px;border-radius:10px;
  background:rgba(168,85,247,.08);
  border:1px solid rgba(168,85,247,.2);
  color:#e9e6ff;font-size:.9rem;
  transition:.25s;
}
.err-links a:hover{background:rgba(168,85,247,.2);border-color:#a855f7;transform:translateY(-2px)}

/* ==== IMAGENS NA HOME — tamanhos contidos ==== */
.hero-figure{
  margin:48px auto 0;
  max-width:760px;          /* antes 1100 — bem menor */
  position:relative;
  isolation:isolate;
}
.hero-figure img{
  width:100%;height:auto;display:block;
  aspect-ratio:16/9;
  object-fit:cover;
  border-radius:18px;
  box-shadow:0 20px 50px rgba(0,0,0,.55),0 0 0 1px rgba(168,85,247,.3);
}
.hero-figure::before{
  content:"";position:absolute;inset:-2px;border-radius:20px;z-index:-1;
  background:linear-gradient(135deg,#a855f7,#06b6d4,#ec4899);
  filter:blur(24px);opacity:.35;
}

/* GRID DE IMAGENS — cards menores */
.img-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin:36px auto 0;
  max-width:1000px;
}
.iptv-img-card{
  position:relative;border-radius:16px;overflow:hidden;
  box-shadow:0 12px 30px rgba(0,0,0,.45);
  border:1px solid rgba(168,85,247,.22);
  transition:transform .3s,box-shadow .3s;
}
.iptv-img-card img{
  width:100%;height:auto;display:block;
  aspect-ratio:4/3;
  object-fit:cover;
}
.iptv-img-card figcaption{
  position:absolute;bottom:0;left:0;right:0;
  padding:14px 16px 12px;
  background:linear-gradient(180deg,transparent,rgba(5,1,15,.92));
  color:#fff;font-weight:700;font-size:.92rem;
  text-align:left;
}
.iptv-img-card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 40px rgba(0,0,0,.55),0 0 0 1px #a855f7;
}

@media (max-width:780px){
  .hero-figure{max-width:92%;margin-top:36px}
  .img-grid{grid-template-columns:1fr 1fr;max-width:560px;gap:14px}
}
@media (max-width:480px){
  .img-grid{grid-template-columns:1fr;max-width:380px}
}

/* ==== EXPLORE — INTERLINKING INTERNO ==== */
.explore-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:16px;
  margin-top:40px;
}
.explore-card{
  display:flex;flex-direction:column;gap:8px;
  padding:22px 22px 24px;
  border-radius:16px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(168,85,247,.18);
  text-decoration:none;color:inherit;
  transition:.3s;
  position:relative;overflow:hidden;
}
.explore-card::after{
  content:"→";
  position:absolute;top:18px;right:20px;
  font-size:1.1rem;color:#c084fc;
  transition:.3s;
}
.explore-card:hover{
  transform:translateY(-4px);
  background:rgba(168,85,247,.1);
  border-color:rgba(168,85,247,.5);
  box-shadow:0 14px 40px rgba(168,85,247,.2);
}
.explore-card:hover::after{transform:translateX(4px);color:#fff}
.explore-icon{
  font-size:1.6rem;
  width:42px;height:42px;border-radius:12px;
  background:linear-gradient(135deg,rgba(168,85,247,.2),rgba(6,182,212,.15));
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(168,85,247,.3);
  margin-bottom:6px;
}
.explore-card h3{font-size:1.05rem;color:#fff;font-weight:700;margin:0}
.explore-card p{color:#b8aedf;font-size:.88rem;line-height:1.55;margin:0}

/* ==== REFERÊNCIAS EXTERNAS ==== */
.ref-list{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:14px;
  margin-top:36px;
}
.ref-list li{list-style:none}
.ref-list a{
  display:flex;flex-direction:column;gap:4px;
  padding:18px 20px;border-radius:14px;
  background:rgba(255,255,255,.02);
  border:1px solid rgba(6,182,212,.18);
  text-decoration:none;
  transition:.3s;
}
.ref-list a:hover{
  background:rgba(6,182,212,.08);
  border-color:rgba(6,182,212,.5);
  transform:translateY(-3px);
}
.ref-list strong{color:#7dd3fc;font-size:.98rem;font-weight:700}
.ref-list span{color:#a59bd9;font-size:.84rem;line-height:1.5}
.ref-note{
  display:block;text-align:center;
  margin-top:24px;
  color:#7d76a8;font-size:.78rem;font-style:italic;
}

/* ========== BLOG ========== */
.posts-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:24px;
  margin-top:40px;
}
.post-card{
  display:flex;flex-direction:column;
  border-radius:18px;overflow:hidden;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(168,85,247,.2);
  text-decoration:none;color:inherit;
  transition:.3s;
}
.post-card:hover{
  transform:translateY(-6px);
  border-color:rgba(168,85,247,.5);
  box-shadow:0 20px 50px rgba(168,85,247,.25);
}
.post-card figure{margin:0;overflow:hidden;background:#0a0118}
.post-card figure img{
  width:100%;height:auto;display:block;
  aspect-ratio:16/9;object-fit:cover;
  transition:transform .5s;
}
.post-card:hover figure img{transform:scale(1.04)}
.post-card-body{padding:22px 22px 24px;display:flex;flex-direction:column;gap:10px;flex:1}
.post-card-tag{
  display:inline-block;
  padding:4px 10px;border-radius:999px;
  background:rgba(192,132,252,.15);color:#c084fc;
  font-size:.72rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  align-self:flex-start;
}
.post-card-body h2{
  font-size:1.15rem;color:#fff;font-weight:800;line-height:1.3;margin:0;
}
.post-card-body p{
  color:#b8aedf;font-size:.92rem;line-height:1.55;margin:0;flex:1;
}
.post-card-link{
  color:#c084fc;font-weight:700;font-size:.9rem;
  margin-top:6px;
}

/* POST PAGE */
.post{max-width:840px;margin:0 auto;padding:60px clamp(20px,5vw,40px)}
.post-header{margin-bottom:36px}
.breadcrumb{
  font-size:.85rem;color:#a59bd9;margin-bottom:18px;
}
.breadcrumb a{color:#c084fc;text-decoration:none}
.breadcrumb a:hover{text-decoration:underline}
.post-title{
  font-size:clamp(1.8rem,4vw,2.6rem);
  font-weight:900;color:#fff;line-height:1.15;margin:14px 0;
}
.post-meta{color:#a59bd9;font-size:.92rem;margin:0}
.post-hero{margin:0 0 40px;border-radius:20px;overflow:hidden;border:1px solid rgba(168,85,247,.25);box-shadow:0 16px 40px rgba(0,0,0,.5)}
.post-hero img{width:100%;height:auto;display:block;aspect-ratio:16/9;object-fit:cover}
.post-body{font-size:1.04rem;line-height:1.75;color:#cfc6ff}
.post-intro{
  font-size:1.12rem;color:#e2dcff;margin-bottom:32px;
  padding:24px;border-radius:14px;
  background:rgba(168,85,247,.06);
  border-left:3px solid #a855f7;
}
.post-intro p:not(:last-child){margin-bottom:14px}
.post-section{margin-bottom:32px}
.post-section h2{
  font-size:1.5rem;font-weight:800;color:#fff;
  margin:0 0 16px;line-height:1.3;
}
.post-section p,.post-section ul{margin-bottom:14px}
.post-section strong{color:#fff;font-weight:600}
.post-section a{color:#c084fc;text-decoration:underline;text-decoration-color:rgba(192,132,252,.4);text-underline-offset:3px}
.post-section a:hover{color:#fff;text-decoration-color:#fff}
.post-section ul{padding-left:22px}
.post-section ul li{margin-bottom:8px;list-style:disc;color:#cfc6ff}
.post-section ul li::marker{color:#c084fc}
.post-section code{background:rgba(168,85,247,.15);padding:2px 8px;border-radius:6px;font-size:.92rem;color:#fff}

.post-cta{
  margin-top:50px;padding:32px;border-radius:18px;
  background:linear-gradient(135deg,rgba(168,85,247,.15),rgba(236,72,153,.1));
  border:1px solid rgba(168,85,247,.4);text-align:center;
}
.post-cta h3{color:#fff;font-size:1.4rem;font-weight:800;margin-bottom:10px}
.post-cta p{color:#e2dcff;margin-bottom:20px}

/* RELATED POSTS */
.related-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:16px;margin-top:30px;
}
.related-card{
  display:flex;flex-direction:column;gap:10px;
  border-radius:14px;overflow:hidden;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(168,85,247,.18);
  text-decoration:none;color:inherit;
  transition:.3s;
}
.related-card:hover{transform:translateY(-4px);border-color:rgba(168,85,247,.45)}
.related-card img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.related-card > div{padding:14px 16px 18px;display:flex;flex-direction:column;gap:6px;flex:1}
.related-tag{
  font-size:.7rem;font-weight:700;color:#c084fc;text-transform:uppercase;letter-spacing:.5px;
}
.related-card h3{font-size:.98rem;color:#fff;font-weight:700;line-height:1.35;margin:0}
