:root{
  --bg:#050505;
  --panel: rgba(255,255,255,.06);
  --panel2: rgba(255,255,255,.08);
  --text:#e9e9e9;
  --muted:#b8b8b8;
  --red:#e50914;
  --gold:#f5c518;
  --shadow: 0 12px 40px rgba(0,0,0,.55);
  --radius: 18px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background: var(--bg);
  overflow-x:hidden;
}

.bg{
  position:fixed; inset:0;
  background:
    radial-gradient(1200px 700px at 15% 10%, rgba(229,9,20,.35), transparent 55%),
    radial-gradient(900px 600px at 80% 20%, rgba(245,197,24,.18), transparent 55%),
    radial-gradient(1100px 900px at 70% 90%, rgba(229,9,20,.10), transparent 55%),
    linear-gradient(180deg, #050505, #070707 40%, #050505);
  z-index:-3;
}
.grain{
  position:fixed; inset:0;
  background-image:url("assets/grain.svg");
  mix-blend-mode:overlay;
  opacity:.35;
  z-index:-2;
  pointer-events:none;
}

/* Topbar */
.topbar{
  position:sticky;
  top:0;
  z-index:50;
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 18px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background: rgba(8,8,8,.78);
  backdrop-filter: blur(16px);
}
.hamburger{
  width:44px; height:44px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.06);
  color:var(--text);
  display:grid;
  place-items:center;
  cursor:pointer;
}
.hamburger span{
  display:block; width:18px; height:2px;
  background: rgba(255,255,255,.85);
  border-radius:99px;
  margin:2px 0;
}
.brand{display:flex; flex-direction:column; gap:4px; min-width: 180px}
.brand-pill{
  font-size:12px; color:rgba(255,255,255,.8);
  padding:6px 10px;
  border-radius:999px;
  width:max-content;
  background: rgba(229,9,20,.15);
  border:1px solid rgba(229,9,20,.25);
}
.brand-title{
  font-family: "Bebas Neue", Inter, sans-serif;
  font-size:30px;
  letter-spacing:1.5px;
  line-height:1;
}

/* NN mark / word-reveal (used in hero title) */
.nn-mark{width:44px; height:44px}
.nn-mark path{fill:none; stroke-width:14; stroke-linecap:square; stroke-linejoin:miter}
.nn-mark .nn-left, .nn-mark .nn-right{transform-origin:50% 50%; transition: transform 1.25s cubic-bezier(.16,1,.3,1)}
.nn-reveal{
  position:absolute;
  left:50%; top:50%;
  transform: translate(-50%,-50%) scale(.985);
  font-family: "Bebas Neue", Inter, sans-serif;
  letter-spacing:2px;
  font-size:18px;
  color: rgba(255,255,255,.92);
  text-shadow: 0 10px 24px rgba(0,0,0,.65), 0 0 26px rgba(229,9,20,.25);
  opacity:0;
  transition: opacity .55s ease, transform 1.25s cubic-bezier(.16,1,.3,1), clip-path 1.1s cubic-bezier(.16,1,.3,1);
  pointer-events:none;
}

/* Hero NN wordmark */
.hero-nn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  vertical-align:middle;
  margin: 0 8px;
  cursor:pointer;
  user-select:none;
}
.hero-nn:focus{outline:none}
.hero-nn:focus-visible{outline:2px solid rgba(229,9,20,.75); outline-offset:6px; border-radius:14px}

.hero-nn-logo{position:relative; width:76px; height:76px; display:grid; place-items:center}
.hero-nn .nn-mark{width:76px; height:76px}
.hero-nn .nn-mark path{stroke-width:16}
.hero-nn .nn-reveal{
  font-size:26px;
  letter-spacing:3px;
  opacity:0;
  clip-path: inset(0 50% 0 50%);
  transform: translate(-50%,-50%) scale(.985) translateY(3px);
  transition-delay: .18s, .18s, .08s;
}

/* Open / hover reveal (longer & smoother) */
.hero-nn.is-open .nn-mark .nn-left{transform: translateX(-18px)}
.hero-nn.is-open .nn-mark .nn-right{transform: translateX(18px)}
.hero-nn.is-open .nn-reveal{opacity:1; clip-path: inset(0 0 0 0); transform: translate(-50%,-50%) scale(1) translateY(0)}

@media (hover:hover) and (pointer:fine){
  .hero-nn:hover .nn-mark .nn-left{transform: translateX(-18px)}
  .hero-nn:hover .nn-mark .nn-right{transform: translateX(18px)}
  .hero-nn:hover .nn-reveal{opacity:1; clip-path: inset(0 0 0 0); transform: translate(-50%,-50%) scale(1) translateY(0)}
}

@media (max-width: 520px){
  .hero-nn-logo{width:64px; height:64px}
  .hero-nn .nn-mark{width:64px; height:64px}
  .hero-nn .nn-reveal{font-size:22px}
  .hero-nn.is-open .nn-mark .nn-left{transform: translateX(-14px)}
  .hero-nn.is-open .nn-mark .nn-right{transform: translateX(14px)}
}



/* Hero NN from text (auto-open word build) */
.hero-nn{
  position:relative;
}
.hero-nn-word{
  display:inline-flex;
  align-items:flex-end;
  position:relative;
  perspective: 900px;
  font-family: "Bebas Neue", Inter, sans-serif;
  letter-spacing: 2px;
  color: #fff;
  text-shadow:
    0 0 10px rgba(229,9,20,.35),
    0 0 22px rgba(229,9,20,.28),
    0 0 44px rgba(229,9,20,.18);
}

/* Pro reveal FX: neon red glow on open (no sweep) */
/* Glow pulse (behind letters) */
/* Light sweep (like a glossy scan) */
.hero-nn-word .nn-letter,
.hero-nn-word .nn-rest{
  display:inline-block;
  will-change: transform, opacity, max-width;
  transition:
    transform 2.85s cubic-bezier(.12,1,.22,1),
    opacity 1.55s cubic-bezier(.2,1,.2,1),
    max-width 2.85s cubic-bezier(.12,1,.22,1),
    filter 1.55s cubic-bezier(.2,1,.2,1);
  filter: blur(0px);
}

/* Netflix red fill */
.hero-nn-word .nn-letter,
.hero-nn-word .nn-rest{
  color: var(--red);
}

/* Collapsed state = looks like 'NN' */
.hero-nn:not(.is-open) .nn-e1,
.hero-nn:not(.is-open) .nn-rest{
  opacity:0;
  max-width:0;
  overflow:hidden;
  transform: translateY(14px) scale(.985);
  filter: blur(8px);
}
.hero-nn:not(.is-open) .nn-e1{ margin:0; }
.hero-nn:not(.is-open) .nn-rest{ margin:0; }

/* Mirror the second visible N while collapsed */
.hero-nn .nn-n2{
  transform-origin: 50% 70%;
  transform-style: preserve-3d;
}
.hero-nn:not(.is-open) .nn-n2{
  transform: rotateY(180deg) translateY(0);
}

/* Open state = show full word */
.hero-nn.is-open .nn-e1{
  opacity:1;
  max-width: 1.2em;
  transform: translateY(0);
  filter: blur(0px);
}
.hero-nn.is-open .nn-n2{
  transform: rotateY(0deg) translateY(0);
}
.hero-nn.is-open .nn-rest{
  opacity:1;
  max-width: 10em;
  transform: translateY(0);
  filter: blur(0px);
  transition-delay: .38s, .38s, .18s, .18s;
}

/* Stagger a tiny bit so it feels like "forming" the word */
.hero-nn.is-open .nn-e1{transition-delay: .38s, .38s, .38s, .38s}
.hero-nn.is-open .nn-n2{transition-delay: .50s, .50s, .50s, .50s}

/* Run the FX once when opened */
.hero-nn.is-open .hero-nn-word{
  animation:
    nnWordPop 1.85s cubic-bezier(.18,.95,.2,1) .18s both,
    nnNeon 2.6s cubic-bezier(.18,.95,.2,1) .18s both;
}
.hero-nn.is-open .hero-nn.is-open @keyframes nnGlow{
  0%{transform: scale(.90); opacity:0}
  35%{transform: scale(1.05); opacity:.95}
  100%{transform: scale(1.00); opacity:.35}
}

@keyframes nnNeon{
  0%{
    filter: drop-shadow(0 0 0 rgba(229,9,20,0));
    text-shadow:
      0 0 0 rgba(229,9,20,0),
      0 0 0 rgba(229,9,20,0),
      0 0 0 rgba(229,9,20,0);
    opacity: .92;
  }
  55%{
    filter: drop-shadow(0 18px 42px rgba(229,9,20,.22));
    text-shadow:
      0 0 12px rgba(229,9,20,.55),
      0 0 30px rgba(229,9,20,.35),
      0 0 60px rgba(229,9,20,.22);
    opacity: 1;
  }
  100%{
    filter: drop-shadow(0 14px 34px rgba(229,9,20,.14));
    text-shadow:
      0 0 10px rgba(229,9,20,.40),
      0 0 24px rgba(229,9,20,.30),
      0 0 48px rgba(229,9,20,.18);
    opacity: 1;
  }
}

@keyframes nnWordPop{
  0%{transform: translateY(6px) scale(.98); filter: drop-shadow(0 0 0 rgba(229,9,20,0))}
  55%{transform: translateY(0px) scale(1.03); filter: drop-shadow(0 18px 38px rgba(229,9,20,.22))}
  100%{transform: translateY(0px) scale(1); filter: drop-shadow(0 14px 32px rgba(229,9,20,.12))}
}

@keyframes nnSheen{
  0%{transform: translateX(-140%) skewX(-18deg); opacity:0}
  18%{opacity:.35}
  52%{opacity:.22}
  100%{transform: translateX(140%) skewX(-18deg); opacity:0}
}

/* Accessibility: keep pointer behaviour but don't show focus ring too aggressive */
.hero-nn[role="button"]{border-radius:14px}

.quick{margin-left:auto; display:flex; gap:10px; align-items:center}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px;
  height:44px;
  padding:0 16px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.06);
  color:var(--text);
  text-decoration:none;
  font-weight:600;
  box-shadow: 0 8px 22px rgba(0,0,0,.35);
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
  white-space:nowrap;
}
.btn:hover{transform: translateY(-1px); background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.16)}
.btn:active{transform: translateY(0px)}
.btn-primary{
  background: linear-gradient(180deg, rgba(229,9,20,1), rgba(180,6,14,1));
  border-color: rgba(229,9,20,.65);
  box-shadow: 0 16px 40px rgba(229,9,20,.25);
}
.btn-primary:hover{background: linear-gradient(180deg, rgba(255,20,35,1), rgba(180,6,14,1))}
.btn-ghost{
  background: rgba(255,255,255,.04);
}
.btn-whatsapp{
  background: rgba(37,211,102,.10);
  border-color: rgba(37,211,102,.30);
}
.btn-whatsapp img{width:18px; height:18px}

main{padding-bottom:60px}
.hero{
  padding: 38px 18px 22px;
}
.hero-grid{
  max-width: 980px;
  margin: 0 auto;
  display:grid;
  grid-template-columns: 1fr;
  gap: 18px;
  align-items:stretch;
}
.hero-copy{
  padding: 18px;
}
.hero h1{
  font-family: "Bebas Neue", Inter, sans-serif;
  font-size: clamp(48px, 5vw, 84px);
  line-height: .95;
  margin: 10px 0 14px;
  letter-spacing: 1.2px;
}
.accent{color:var(--red)}
.hero p{
  margin:0 0 18px;
  color: rgba(255,255,255,.85);
  font-size: 16px;
  max-width: 52ch;
}
.price-card{
  background: var(--panel);
  border:1px solid rgba(255,255,255,.10);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 18px;
  display:flex;
  gap: 16px;
  align-items:center;
}
.price{
  min-width: 132px;
  padding: 14px;
  border-radius: 16px;
  background: rgba(0,0,0,.35);
  border: 1px solid rgba(255,255,255,.10);
}
.price-num{
  font-family: "Bebas Neue", Inter, sans-serif;
  font-size: 56px;
  line-height: 1;
  color: #fff;
}
.price-sub{color: rgba(255,255,255,.75); margin-top:6px; font-weight:600}
.badges{display:flex; flex-wrap:wrap; gap:10px}
.badge{
  padding:8px 10px;
  border-radius:999px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.85);
  font-weight:600;
  font-size: 13px;
}

.cta-row{display:flex; gap:10px; margin-top:14px; flex-wrap:wrap}
.tip{
  margin-top:14px;
  padding:12px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.82);
}
.tip-pill{
  display:inline-flex;
  font-weight:800;
  letter-spacing:.8px;
  font-size:12px;
  padding:4px 10px;
  border-radius:999px;
  background: rgba(245,197,24,.18);
  border:1px solid rgba(245,197,24,.28);
  color: #fff;
  margin-right:8px;
}

.hero-media{
  position:relative;
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  box-shadow: var(--shadow);
  overflow:hidden;
  min-height: 360px;
}
.hero-glow{
  position:absolute; inset:-40%;
  background: radial-gradient(circle at 30% 20%, rgba(229,9,20,.35), transparent 45%),
              radial-gradient(circle at 70% 60%, rgba(245,197,24,.18), transparent 50%);
  filter: blur(12px);
  opacity:.9;
}
.poster-wall{
  position:absolute; inset:0;
  padding: 18px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  transform: perspective(900px) rotateY(-8deg) rotateX(4deg);
}
.poster{
  border-radius: 14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.20), rgba(255,255,255,.03)),
    radial-gradient(120px 120px at 20% 20%, rgba(229,9,20,.35), transparent 50%),
    radial-gradient(140px 120px at 70% 80%, rgba(245,197,24,.22), transparent 55%),
    rgba(0,0,0,.35);
  border:1px solid rgba(255,255,255,.10);
  box-shadow: 0 10px 24px rgba(0,0,0,.45);
  position:relative;
  overflow:hidden;
}
.poster:after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.65));
  opacity:.85;
}
.poster.p2,.poster.p4,.poster.p7{transform: translateY(6px)}
.poster.p3,.poster.p6,.poster.p8{transform: translateY(14px)}
.poster.p5{transform: translateY(-6px)}
.poster-wall.float{animation: floaty 7s ease-in-out infinite}
@keyframes floaty{
  0%,100%{transform: perspective(900px) rotateY(-8deg) rotateX(4deg) translateY(0)}
  50%{transform: perspective(900px) rotateY(-8deg) rotateX(4deg) translateY(-10px)}
}

.scroll-hint{
  max-width:1180px;
  margin: 14px auto 0;
  color: rgba(255,255,255,.75);
  display:flex; align-items:center; gap:10px;
  padding: 0 18px;
}
.scroll-hint .dot{
  width:8px;height:8px;border-radius:99px;background: var(--red);
  box-shadow: 0 0 0 6px rgba(229,9,20,.20);
}

.section{
  max-width: 1180px;
  margin: 0 auto;
  padding: 34px 18px 0;
}
.section-head h2{
  font-family: "Bebas Neue", Inter, sans-serif;
  font-size: 44px;
  letter-spacing: 1px;
  margin: 0 0 8px;
}
.section-head p{
  margin:0;
  color: rgba(255,255,255,.75);
  max-width: 70ch;
}

.cards{
  margin-top: 16px;
  display:grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
.card{
  background: var(--panel);
  border:1px solid rgba(255,255,255,.10);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: var(--shadow);
}
.card h3{margin:0 0 8px}
.card p{margin:0; color: rgba(255,255,255,.78)}

.pdf-grid{
  margin-top: 18px;
  display:grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
.page{
  background: rgba(0,0,0,.28);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: var(--shadow);
}
.page-head{
  display:flex; align-items:center; justify-content:space-between;
  padding: 12px 14px;
  background: rgba(255,255,255,.04);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.page-title{
  display:flex; gap:10px; align-items:center;
  font-weight:800;
}
.page-chip{
  width:28px; height:28px;
  border-radius: 10px;
  display:grid; place-items:center;
  background: rgba(229,9,20,.16);
  border:1px solid rgba(229,9,20,.30);
  color:#fff;
  font-weight:900;
}
.page img{
  width:100%;
  height:auto;
  display:block;
  cursor: zoom-in;
}


/* Guide: neon dividers between slides (Netflix-futuristic vibe)
   NOTE: this is a real DOM element (.neon-divider) so it remains visible
   even when .page has overflow:hidden for the images. */
.page-guide .pdf-grid .page{position:relative}
.neon-divider{
  position:relative;
  height: 14px;
  margin: -2px 0 6px;
  pointer-events:none;
}
.neon-divider.reveal{opacity:1; transform:none}
.neon-divider::before{
  content:"";
  position:absolute;
  left: 16px;
  right: 16px;
  top: 50%;
  height: 2px;
  transform: translateY(-50%);
  background: linear-gradient(90deg,
    rgba(0,0,0,0) 0%,
    rgba(229,9,20,.95) 18%,
    rgba(0,255,255,.55) 50%,
    rgba(229,9,20,.95) 82%,
    rgba(0,0,0,0) 100%);
  box-shadow:
    0 0 10px rgba(229,9,20,.35),
    0 0 22px rgba(229,9,20,.25),
    0 0 14px rgba(0,255,255,.18);
  filter: blur(.2px);
  opacity: .95;
  animation: neonDividerPulse 2.2s ease-in-out infinite;
}
.neon-divider::after{
  content:"";
  position:absolute;
  left: 22px;
  right: 22px;
  top: 50%;
  height: 10px;
  transform: translateY(-50%);
  background: radial-gradient(circle at 30% 50%, rgba(229,9,20,.22), rgba(0,0,0,0) 55%),
              radial-gradient(circle at 70% 50%, rgba(0,255,255,.12), rgba(0,0,0,0) 55%);
  opacity: .9;
  animation: neonDividerSweep 3.6s ease-in-out infinite;
}
@keyframes neonDividerPulse{
  0%,100%{opacity:.65; filter: blur(.15px)}
  50%{opacity:1; filter: blur(.6px)}
}

@keyframes neonDividerSweep{
  0%,100%{transform: translateY(-50%) translateX(-6px); opacity:.55}
  50%{transform: translateY(-50%) translateX(6px); opacity:1}
}

/* Subtle neon edge glow on each page card */
.page-guide .pdf-grid .page::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  pointer-events:none;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.06) inset,
    0 0 22px rgba(229,9,20,.10),
    0 0 34px rgba(0,255,255,.06);
  opacity:.75;
}
.accordion{margin-top: 16px; display:grid; gap:12px}
details{
  background: var(--panel);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--radius);
  padding: 14px 16px;
  box-shadow: var(--shadow);
}
summary{
  cursor:pointer;
  font-weight:800;
  list-style:none;
}
summary::-webkit-details-marker{display:none}
.details-body{
  padding-top: 12px;
  color: rgba(255,255,255,.78);
  line-height:1.55;
}

.footer{padding-bottom: 40px}
.footer-card{
  margin-top: 20px;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  border: 1px solid rgba(255,255,255,.10);
  border-radius: calc(var(--radius) + 6px);
  padding: 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  box-shadow: var(--shadow);
}
.footer-card h2{margin:0 0 6px}
.footer-card p{margin:0; color: rgba(255,255,255,.75)}
.footer-actions{display:flex; gap:10px; flex-wrap:wrap}
.footer-mini{
  margin-top: 14px;
  color: rgba(255,255,255,.55);
  text-align:center;
  font-size: 13px;
}

/* Lightbox */
.lightbox{
  position:fixed; inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  background: rgba(0,0,0,.78);
  backdrop-filter: blur(8px);
  z-index: 60;
  padding: 16px;
}
.lightbox.open{display:flex}
.lightbox img{
  max-width: min(1100px, 96vw);
  max-height: 92vh;
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.12);
  box-shadow: 0 18px 60px rgba(0,0,0,.65);
}
.lightbox-close{
  position:fixed;
  top: 16px; right: 16px;
  width: 44px; height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  color: #fff;
  font-size: 18px;
  cursor:pointer;
}

/* Drawer */
.drawer{
  position:fixed; inset:0;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(8px);
  z-index: 70;
  display:none;
  padding: 18px;
}
.drawer.open{display:block}
.drawer-card{
  max-width: 420px;
  margin-left:auto;
  background: rgba(10,10,10,.92);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 22px;
  padding: 14px;
  box-shadow: 0 20px 70px rgba(0,0,0,.75);
}
.drawer-head{display:flex; align-items:center; justify-content:space-between}
.drawer-title{font-weight:900}
.drawer-close{
  width: 40px; height: 40px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  color:#fff;
  cursor:pointer;
}
.drawer-actions{display:grid; gap:10px; margin-top: 12px}
.w100{width:100%}
.drawer-note{margin-top: 12px; color: rgba(255,255,255,.68); font-size: 13px; line-height:1.4}

/* Back to top (bigger, Netflix-ish) */
.to-top{
  position:fixed;
  right: 16px;
  bottom: 16px;
  width: 56px;
  height: 56px;
  border-radius: 18px;
  border: 1px solid rgba(229,9,20,.45);
  background: linear-gradient(180deg, rgba(229,9,20,1), rgba(180,6,14,1));
  color: #fff;
  font-size: 22px;
  font-weight: 900;
  cursor:pointer;
  box-shadow: 0 18px 50px rgba(229,9,20,.22);
  display:none;
}
.to-top.show{display:block}

/* Reveal on scroll */
.reveal{
  opacity:0;
  transform: translateY(14px);
  transition: opacity .6s ease, transform .6s ease;
}
.reveal.show{opacity:1; transform: translateY(0)}

/* Responsive */
@media (max-width: 980px){
  .hero-grid{grid-template-columns: 1fr}
  .hero-media{min-height: 280px}
  .cards{grid-template-columns: 1fr}
  .pdf-grid{grid-template-columns: 1fr}
  .quick{display:none}
  .brand{min-width: unset}
}

/* v2 tweaks: centered hero + full-width scroll */
.hero-copy{padding: 8px 6px}
.hero p{max-width: 62ch}
.price-card{flex-direction: column; align-items:flex-start}
.price{width: 100%}
.badges{width:100%}

/* v3: centered hero title */
.hero-copy.centered{ text-align:center; margin: 0 auto; }
.hero-copy.centered .price-card{ align-items:center; }
.hero-copy.centered .badges{ justify-content:center; }
.hero-copy.centered .cta-row{ justify-content:center; }
.hero-copy.centered .tip{ text-align:left; max-width: 820px; margin-left:auto; margin-right:auto; }
.hero-copy.centered .price{ max-width: 520px; }

/* v3: remove headers on pages; show subtle overlay */
.page{ position: relative; }
/* v3+: scroll progress (always-visible track + filling bar)
   - Track stays visible on desktop + mobile
   - Bar fills smoothly (JS updates width) */
.progress{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:3px;
  background: rgba(255,255,255,.10);
  z-index: 80;
  pointer-events:none;
}
.progress-bar{
  height:100%;
  width:0%;
  background: linear-gradient(90deg, rgba(229,9,20,1), rgba(245,197,24,1));
  box-shadow: 0 8px 18px rgba(229,9,20,.25);
  will-change: width;
}
html{scroll-behavior:smooth}

/* v3: richer effects */
.btn-primary{ position:relative; overflow:hidden; }
.btn-primary:before{
  content:"";
  position:absolute; inset:-2px;
  background: conic-gradient(from 180deg, rgba(229,9,20,.0), rgba(245,197,24,.35), rgba(229,9,20,.0));
  opacity:.55;
  filter: blur(10px);
  transform: translateX(-30%);
  animation: shimmer 3.2s linear infinite;
}
.btn-primary > *{ position:relative; z-index:1; }
@keyframes shimmer{
  0%{ transform: translateX(-35%) rotate(0deg); }
  100%{ transform: translateX(35%) rotate(360deg); }
}
.page{
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.page:hover{
  transform: translateY(-2px) scale(1.01);
  border-color: rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
}
.page img{ transition: transform .35s ease; transform-origin:center; }
.page:hover img{ transform: scale(1.015); }

/* subtle neon separators */
.section-head h2{
  text-shadow: 0 0 22px rgba(229,9,20,.18);
}

/* ===== v5 Mobile-first Premium ===== */

/* Topbar: more compact on mobile */
@media (max-width: 980px){
  .topbar--v5{padding: 10px 12px; gap:10px}
  .hamburger{width:42px;height:42px;border-radius:14px}
  /* Mobile: logo aligned left (requested) */
  .brand-title{font-size:28px; text-align:left}
  .brand-pill{font-size:11px}
  .brand{flex:1; align-items:flex-start}
}


/* Hero: better readability on mobile */
@media (max-width: 980px){
  .hero{padding-top: 22px}
  .hero h1{font-size: clamp(44px, 9vw, 64px); text-align:center}
  .hero p{margin-left:auto;margin-right:auto; text-align:center; font-size:16px; line-height:1.6}
  .cta-row{justify-content:center}
  .tip{font-size:14px; line-height:1.5}
}

/* FAB (WhatsApp + Peticiones) */
.fab{
  position: fixed;
  right: 14px;
  bottom: 88px;
  display:flex;
  flex-direction: column;
  gap: 10px;
  z-index: 75;
}
.fab-btn{
  width: 54px;
  height: 54px;
  border-radius: 18px;
  display:grid;
  place-items:center;
  text-decoration:none;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 18px 60px rgba(0,0,0,.55);
  backdrop-filter: blur(10px);
  transform: translateZ(0);
  transition: transform .16s ease, filter .16s ease;
}
.fab-btn:hover{transform: translateY(-2px) scale(1.02)}
.fab-wa{background: rgba(37,211,102,.14); border-color: rgba(37,211,102,.30)}
.fab-wa img{width:22px;height:22px}
.fab-pet{background: rgba(229,9,20,.16); border-color: rgba(229,9,20,.35); color:#fff; font-size:20px}
@media (min-width: 981px){
  .fab{right:18px; bottom: 94px}
}

/* Lightbox navigation */
.lightbox-nav{
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  width: 46px;
  height: 46px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  color: #fff;
  font-size: 28px;
  cursor:pointer;
  z-index: 61;
  display:none;
}
.lightbox.open .lightbox-nav{display:block}
.lightbox-nav.prev{left: 12px}
.lightbox-nav.next{right: 12px}
@media (max-width: 980px){
  .lightbox-nav.prev{left: 10px}
  .lightbox-nav.next{right: 10px}
}

/* Reduce grain on mobile for performance */
@media (max-width: 980px){
  .grain{opacity:.20}
}

/* Better tap targets */
@media (max-width: 980px){
  .btn{height:46px}
  .to-top{width:60px;height:60px}
}

/* ===== v6 fixes: hero lead centering + nicer rhythm ===== */
.hero-copy.centered{ text-align:center; margin: 0 auto; }
.hero-copy.centered .hero-lead{
  margin: 0 auto 18px;
  max-width: 56ch;
  text-align: center;
}
.hero-divider{
  width: min(420px, 78vw);
  height: 2px;
  margin: 0 auto 16px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(229,9,20,0), rgba(229,9,20,.65), rgba(245,197,24,.45), rgba(229,9,20,.65), rgba(229,9,20,0));
  opacity: .65;
  filter: blur(.2px);
}

/* Ensure hero-copy internal blocks center nicely even when flex wraps */
.hero-copy.centered .price-card{ margin-left:auto; margin-right:auto; }
.hero-copy.centered @media (max-width: 980px){
  .hero-copy.centered .hero-lead{max-width: 60ch}
  .hero-divider{margin-bottom: 14px}
}

/* ===== v7: remove quickstart + mobile pro effects ===== */

/* Softer cinematic glow behind hero */
.hero{
  position: relative;
  overflow: clip;
}
.hero:before{
  content:"";
  position:absolute;
  inset:-40px -60px auto -60px;
  height: 360px;
  background:
    radial-gradient(closest-side, rgba(229,9,20,.20), rgba(229,9,20,0) 70%),
    radial-gradient(closest-side, rgba(245,197,24,.12), rgba(245,197,24,0) 72%);
  filter: blur(8px);
  opacity:.9;
  transform: translate3d(var(--glowX, 0px), var(--glowY, 0px), 0);
  transition: transform .08s linear;
  pointer-events:none;
  z-index:0;
}
.hero > *{ position: relative; z-index:1; }

/* Better reveal on mobile: fade + slight blur + translate */
.reveal{
  opacity: 0;
  transform: translateY(12px) scale(.985);
  filter: blur(6px);
  transition: opacity .55s ease, transform .55s cubic-bezier(.2,.9,.2,1), filter .55s ease;
}
.reveal.in{
  opacity: 1;
  transform: translateY(0) scale(1);
  }

/* Tap ripple for buttons (mobile) */
.btn{
  position: relative;
  overflow: hidden;
  -webkit-tap-highlight-color: transparent;
}
.btn:after{
  content:"";
  position:absolute;
  inset:auto;
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.35);
  transform: translate(-50%,-50%) scale(0);
  opacity: 0;
  pointer-events:none;
}
.btn.ripple:after{
  left: var(--rx, 50%);
  top: var(--ry, 50%);
  animation: ripple .55s ease-out;
}
@keyframes ripple{
  0%{ transform: translate(-50%,-50%) scale(0); opacity:.0; }
  15%{ opacity:.55; }
  100%{ transform: translate(-50%,-50%) scale(26); opacity:0; }
}

/* Slight “premium” scroll snap feel for the guide pages on mobile (not true snap, just spacing) */
@media (max-width: 980px){
  .pdf-grid{ gap: 14px; }
  .page{ border-radius: 18px; }
  }

/* Reduce motion preference */
@media (prefers-reduced-motion: reduce){
  .reveal{ transition:none; transform:none; filter:none; opacity:1; }
  .hero:before{ transition:none; }
}

/* v8: never leave content blurred */
.reveal{filter:none !important}

/* v9: hide any leftover step marks */
.hero .steps, .hero .qs-steps, .hero .quickstart, .hero .step-bullets{display:none !important}

/* ===== v10: WhatsApp-first upgrades ===== */
.hide-mobile{display:inline}
@media (max-width: 980px){ .hide-mobile{display:none} }

.segmented{
  display:flex;
  gap:6px;
  padding:6px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 14px 40px rgba(0,0,0,.35);
}
.seg-btn{
  border:0;
  background: transparent;
  color: rgba(255,255,255,.86);
  font-weight: 900;
  padding: 8px 12px;
  border-radius: 999px;
  cursor:pointer;
  font-size: 13px;
}
.seg-btn.active{
  background: rgba(229,9,20,.20);
  border: 1px solid rgba(229,9,20,.35);
  color:#fff;
}
.btn-icon .icon{margin-right:8px}
@media (max-width: 980px){
  .seg-btn{padding:8px 10px; font-size:12px}
  .btn-icon .icon{margin-right:0}
}

/* Search */
.guide-tools{margin-top:10px; display:flex; flex-direction:column; gap:8px; align-items:stretch}
.search{
  width:100%;
  height: 44px;
  border-radius: 16px;
  padding: 0 14px;
  background: rgba(0,0,0,.35);
  border: 1px solid rgba(255,255,255,.12);
  color: #fff;
  outline:none;
}
.search:focus{border-color: rgba(245,197,24,.35); box-shadow: 0 0 0 4px rgba(245,197,24,.08)}
.search-hint{font-size: 12px; color: rgba(255,255,255,.70)}

/* Easy mode cards */
.easy-mode{display:none}
.easy-mode.active{display:block}
.full-guide{display:block}
.full-guide.hidden{display:none}

.easy-grid{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 14px;
}
@media (max-width: 980px){ .easy-grid{grid-template-columns: 1fr} }

.easy-card{
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 20px;
  padding: 14px;
  box-shadow: 0 16px 44px rgba(0,0,0,.45);
}
.easy-kicker{font-weight:900; color: rgba(245,197,24,.92); letter-spacing:.02em; font-size:12px; margin-bottom:6px}
.easy-title{font-weight: 1000; font-size: 18px; margin-bottom:6px}
.easy-text{color: rgba(255,255,255,.78); line-height:1.55; margin-bottom:10px}
.easy-media{
  border-radius: 16px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.35);
}
.easy-media img{width:100%; height:auto; display:block}
.easy-actions{display:flex; justify-content:flex-start}

/* Skeleton shimmer for images */
img[loading="lazy"]{
  background: linear-gradient(90deg, rgba(255,255,255,.06), rgba(255,255,255,.10), rgba(255,255,255,.06));
  background-size: 200% 100%;
  animation: shimmerImg 1.3s linear infinite;
}
img.is-loaded{
  animation:none;
  background:none;
}
@keyframes shimmerImg{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}

/* FAQ */
.req, .faq{
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 20px;
  padding: 14px;
  box-shadow: 0 16px 44px rgba(0,0,0,.45);
}
.req{margin-top: 12px}
.req-title{font-weight: 1000; margin-bottom: 8px}
.req-list{margin:0; padding-left: 18px; color: rgba(255,255,255,.82); line-height:1.6}

.faq{margin-top: 12px}
.faq-q{
  width:100%;
  text-align:left;
  border:0;
  background: rgba(0,0,0,.25);
  border: 1px solid rgba(255,255,255,.10);
  color:#fff;
  padding: 12px 12px;
  border-radius: 16px;
  cursor:pointer;
  font-weight: 900;
  margin-bottom: 10px;
}
.faq-a{
  display:none;
  color: rgba(255,255,255,.78);
  margin: -4px 0 12px;
  padding: 0 8px 10px 8px;
  line-height: 1.55;
}
.faq-q.open + .faq-a{display:block}

/* Data saver: reduce effects */
body.save-data .grain{opacity:.08}
body.save-data .progress{display:none}
body.save-data .page:hover img{transform:none}
body.save-data .btn-primary:before{display:none}

/* v11: search result pulse */
.page.pulse{
  outline: 2px solid rgba(245,197,24,.65);
  box-shadow: 0 0 0 6px rgba(245,197,24,.14), 0 22px 70px rgba(0,0,0,.55);
}

/* ===== v12 Premium Mobile Enhancements ===== */

/* Hero title animation */
.hero h1{
  animation: heroTitle .8s cubic-bezier(.2,.9,.2,1) both;
}
.hero p{
  animation: heroSub .8s .2s cubic-bezier(.2,.9,.2,1) both;
}
@keyframes heroTitle{
  from{opacity:0; transform: translateY(10px) scale(.98)}
  to{opacity:1; transform:none}
}
@keyframes heroSub{
  from{opacity:0; transform: translateY(8px)}
  to{opacity:1; transform:none}
}

/* Sticky WhatsApp CTA */
.sticky-wa{
  position: fixed;
  left: 0; right: 0; bottom: 0;
  padding: 10px 12px env(safe-area-inset-bottom);
  background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.75));
  z-index: 80;
  display:none;
}
.sticky-wa-btn{
  display:block;
  text-align:center;
  background: #25D366;
  color:#0b0b0f;
  font-weight: 900;
  border-radius: 18px;
  padding: 14px;
  text-decoration:none;
  box-shadow: 0 18px 60px rgba(0,0,0,.55);
}
@media (max-width: 980px){
  .sticky-wa{display:block}
}

/* Scroll reveal polish */
.reveal{
  transition: opacity .5s ease, transform .5s ease;
}

/* ===== v13: trust bar + one-time logo anim + dynamic CTA ===== */
.trustbar{
  margin: 12px auto 0;
  max-width: 820px;
  display:flex;
  gap: 10px;
  justify-content:center;
  flex-wrap: wrap;
}
.trust-item{
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.85);
  font-weight: 900;
  letter-spacing: .01em;
  font-size: 13px;
  box-shadow: 0 14px 40px rgba(0,0,0,.35);
}
@media (max-width: 980px){
  .trust-item{font-size:12px; padding: 9px 11px}
}

/* One-time hero title animation (Netflix-ish) */
.hero h1.logo-once{
  animation: logoOnce .72s cubic-bezier(.2,.9,.2,1) both;
}
@keyframes logoOnce{
  0%{opacity:0; transform: translateY(10px) scale(.98); letter-spacing:.14em;}
  55%{opacity:1;}
  100%{transform:none; letter-spacing:.02em;}
}

/* v14: allow native browser zoom/pan on lightbox images */
.lightbox img{
  transform: none !important;
  touch-action: auto !important;
}

/* v15: cleaner guide cards */
.page img{ display:block; width:100%; height:auto; }

/* ===== Split landing + guide (v15.1) ===== */
 .brand-sub{
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  color: rgba(255,255,255,.62);
  text-transform: uppercase;
  margin-top: 2px;
}
.hero-landing .hero-inner{padding: 18px 16px}
.centered{text-align:center}
.landing-title{
  margin: 0 0 10px;
  font-size: clamp(28px, 7vw, 44px);
  font-weight: 1000;
  letter-spacing: .01em;
}
.landing-lead{max-width: 62ch; margin-left:auto; margin-right:auto}
.cta-row{
  display:flex; gap:10px; justify-content:center; flex-wrap:wrap;
  margin: 14px 0 10px;
}
.btn-lg{height: 46px; padding: 0 16px; border-radius: 18px}
.landing-price{
  max-width: 520px;
  margin: 10px auto 0;
  padding: 14px;
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.28);
}
.landing-price .price-main{font-size: 34px; font-weight: 1000}
.landing-price .price-sub{margin-top:6px; color: rgba(255,255,255,.72); font-weight: 700}
.cards{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
  margin-top: 12px;
}
@media (max-width: 980px){
  .cards{grid-template-columns: 1fr}
}
.card{
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 20px;
  padding: 14px;
  box-shadow: 0 16px 44px rgba(0,0,0,.45);
}
.card-title{font-weight: 1000; margin-bottom: 6px}
.card-text{color: rgba(255,255,255,.78); font-weight: 700; line-height:1.55}
.landing-foot{margin-top: 14px; text-align:center}
.landing-note{
  display:inline-block;
  margin: 0 auto;
  padding: 10px 12px;
  border-radius: 18px;
  background: rgba(245,197,24,.08);
  border: 1px solid rgba(245,197,24,.20);
  color: rgba(255,255,255,.86);
  font-weight: 800;
}

/* ===== v15.2: centering + boom hero visuals ===== */
.landing-lead{
  text-align:center !important;
  margin-left:auto !important;
  margin-right:auto !important;
}

/* Boom visuals on landing hero */
.hero-landing .hero-inner{
  position:relative;
  overflow:hidden;
}
.hero-landing .hero-inner:before{
  content:"";
  position:absolute;
  inset:-80px -120px auto -120px;
  height: 420px;
  background: radial-gradient(closest-side, rgba(229,9,20,.22), rgba(229,9,20,0) 70%);
  filter: blur(6px);
  pointer-events:none;
}
.hero-landing .hero-inner:after{
  content:"";
  position:absolute;
  right:-160px;
  top:-120px;
  width: 520px;
  height: 520px;
  background: radial-gradient(closest-side, rgba(245,197,24,.18), rgba(245,197,24,0) 70%);
  filter: blur(8px);
  pointer-events:none;
}
.hero-landing .hero-inner .landing-title{
  position:relative;
}
.hero-landing .hero-inner .landing-title:after{
  content:"";
  display:block;
  width: 86px;
  height: 4px;
  margin: 12px auto 0;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(229,9,20,1), rgba(245,197,24,1));
  opacity:.9;
}
.hero-landing .cta-row{
  position:relative;
}
.btn-primary.btn-lg{
  box-shadow: 0 18px 50px rgba(229,9,20,.22);
}
.back-home{
  margin: 16px 0 26px;
  display:flex;
  justify-content:center;
}

/* ===== v15.3 unified header + mobile polish ===== */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px}
.brand{display:flex;flex-direction:column;text-decoration:none}
.brand-title{font-weight:1000;letter-spacing:.02em}
.brand-sub{font-size:10px;font-weight:900;letter-spacing:.10em;color:rgba(255,255,255,.58);text-transform:uppercase;margin-top:2px}

/* Header nav buttons (compact + "Netflix" vibe) */
.topbar .btn-nav{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:28px;
  padding:0 14px;
  font-size:10.5px;
  font-weight:900;
  letter-spacing:.03em;
  border-radius:999px;
  text-decoration:none;
  white-space:nowrap;

  /* Glass base */
  background: linear-gradient(180deg, rgba(255,255,255,.085), rgba(255,255,255,.045));
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  border:1px solid rgba(255,255,255,.14);

  /* Subtle Netflix hint */
  box-shadow:
    0 10px 24px rgba(0,0,0,.42),
    0 0 0 1px rgba(255,255,255,.06) inset,
    0 0 0 1px rgba(229,9,20,.10);

  color: rgba(255,255,255,.92);
  position:relative;
  overflow:hidden;
  transition: transform .18s ease, background .18s ease, border-color .18s ease, box-shadow .18s ease, filter .18s ease;
}
.topbar .btn-nav:visited{color: rgba(255,255,255,.92)}


/* Soft sheen layer (keeps existing hover/active animation feel) */
.topbar .btn-nav::before{
  content:"";
  position:absolute;
  inset:-1px;
  background: radial-gradient(120px 40px at 20% 0%, rgba(255,255,255,.18), rgba(255,255,255,0) 60%),
              radial-gradient(120px 40px at 80% 120%, rgba(229,9,20,.12), rgba(229,9,20,0) 65%);
  opacity:.75;
  pointer-events:none;
  transition: opacity .18s ease;
}
.topbar .btn-nav > *{position:relative; z-index:1;}
.topbar .btn-nav:hover{
  transform: translateY(-1px);
  background: linear-gradient(180deg, rgba(229,9,20,.14), rgba(255,255,255,.05));
  border-color: rgba(229,9,20,.38);
  box-shadow:
    0 12px 28px rgba(0,0,0,.45),
    0 0 0 1px rgba(229,9,20,.22) inset,
    0 12px 34px rgba(229,9,20,.20);
}
.topbar .btn-nav:hover::before{opacity:.95;}
.topbar .btn-nav:active{
  transform: translateY(0) scale(.98);
  background: linear-gradient(180deg, rgba(229,9,20,.18), rgba(255,255,255,.04));
  border-color: rgba(229,9,20,.48);
  box-shadow:
    0 10px 24px rgba(0,0,0,.45),
    0 0 0 1px rgba(229,9,20,.28) inset,
    0 10px 28px rgba(229,9,20,.22);
}

/* Make sure generic .btn rules don't inflate header buttons */
.topbar .btn{height:auto; border-radius:999px}

/* Mobile nav hamburger removed (requested): keep actions visible on all breakpoints */
.burger{display:none !important;}
@media (max-width: 879px){
  .topbar{padding-left:12px;padding-right:12px}
  .actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
  /* Keep page CTAs comfy, but don't inflate header buttons */
  .actions .btn:not(.btn-nav){padding:10px 12px}
}

/* reduce foggy feeling a bit */
.hero-landing .hero-inner:before{filter: blur(4px); opacity:.85}
.hero-landing .hero-inner:after{filter: blur(6px); opacity:.8}

/* ===== v15.4 tip bar + premium polish ===== */
.tipbar{
  max-width: 980px;
  margin: 14px auto 0 auto !important;
  border-radius: 18px !important;
  padding: 12px 14px !important;
  background: rgba(255,255,255,.045) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  box-shadow: 0 18px 60px rgba(0,0,0,.45) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.tipbar .tipchip{
  background: rgba(229,9,20,.14) !important;
  border: 1px solid rgba(229,9,20,.25) !important;
  color: rgba(255,255,255,.92) !important;
  font-weight: 900 !important;
  border-radius: 999px !important;
  padding: 5px 10px !important;
}
@media (max-width: 560px){
  .tipbar{margin: 10px 12px 0 12px !important;}
}

/* reduce overall haze slightly on mobile */
@media (max-width: 560px){
  .bg-glow{filter: blur(22px) saturate(1.05) !important; opacity:.70 !important;}
}

/* ===== v15.5 Netflixy brand + spacing + Android smoothness ===== */
:root{
  --netflix-red: #e50914;
  --netflix-red-soft: rgba(229,9,20,.55);
}

.brand-title{
  color: var(--netflix-red) !important;
  text-shadow: 0 10px 30px rgba(229,9,20,.18), 0 2px 10px rgba(0,0,0,.45);
}

/* Guide header: single-line feel */
.page-guide .brand-sub{ display:none !important; }

/* ===== v15.6: Mobile header sizing balance (topbar) =====
   Problem: on mobile, header buttons looked too large vs brand title/subtitle.
   Fix: make topbar buttons a touch more compact and boost brand typography.
   (Only affects the header; CTA buttons in the page body keep their size.) */

@media (max-width: 560px){
  .topbar{
    padding-top: 10px;
    padding-bottom: 10px;
    gap: 10px;
  }

  .brand-title{
    font-size: 30px;
    letter-spacing: .05em;
    line-height: 1;
  }

  /* "TU STREAMING PRIVADO EN PLEX" very small but crisp */
  .brand-sub{
    font-size: 9px;
    letter-spacing: .14em;
    margin-top: 2px;
    opacity: .92;
  }

  .actions{gap:6px}

  /* Extra compact header buttons on mobile */
  .topbar .btn-nav{
    height: 30px;
    padding: 0 9px;
    font-size: 11.5px;
  }
}

/* Mid-size phones / small tablets: keep header buttons from dominating */
@media (max-width: 879px){
  .topbar .btn-nav{
    height: 32px;
    padding: 0 10px;
    font-size: 12px;
  }
  .brand-title{ font-size: 30px; }
  .brand-sub{ font-size: 10px; }
}

/* On guide, keep subtitle hidden on desktop, but show it on mobile for balance */
@media (max-width: 560px){
  .page-guide .brand-sub{ display:block !important; }
}

body{
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

.section{ padding-top: 28px; padding-bottom: 28px; }
.section h2{ line-height: 1.12; letter-spacing: .01em; }
.section p{ line-height: 1.7; }

html{ scroll-behavior: smooth; }
*{ -webkit-tap-highlight-color: transparent; }

.topbar{
  padding-top: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: rgba(5,5,8,.55);
}

/* Primary button more Netflix */
.btn-primary{
  background: linear-gradient(180deg, rgba(229,9,20,1), rgba(180,0,12,1)) !important;
  box-shadow: 0 14px 40px rgba(229,9,20,.22), 0 2px 10px rgba(0,0,0,.55);
}
.btn-primary:hover{ filter: brightness(1.05); transform: translateY(-1px); }
.btn:focus-visible{ outline: 2px solid rgba(229,9,20,.55) !important; outline-offset: 2px; }

/* TIP bar centered + premium */
.tipbar{
  max-width: 980px;
  margin: 14px auto 0 auto !important;
  border-radius: 18px !important;
  padding: 12px 14px !important;
  background: rgba(255,255,255,.045) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  box-shadow: 0 18px 60px rgba(0,0,0,.45) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.tipbar .tipchip{
  background: rgba(229,9,20,.14) !important;
  border: 1px solid rgba(229,9,20,.25) !important;
  color: rgba(255,255,255,.92) !important;
  font-weight: 900 !important;
  border-radius: 999px !important;
  padding: 5px 10px !important;
}

@media (max-width: 560px){
  .section{ padding-top: 22px; padding-bottom: 22px; }
  .tipbar{ margin: 10px 12px 0 12px !important; }
  .hero-title{ line-height: 1.02 !important; }
  .hero-subtitle{ line-height: 1.55 !important; }
}

/* reduce haze slightly on mobile */
@media (max-width: 560px){
  .bg-glow{filter: blur(22px) saturate(1.05) !important; opacity:.70 !important;}
}

/* ===== v15.6 comparativa + pricing premium ===== */
.price-card{
  position: relative;
  padding: 18px 18px 16px 18px !important;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 18px 70px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.06);
}
.price-card::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius: 22px;
  background: radial-gradient(70% 60% at 30% 10%, rgba(229,9,20,.18), transparent 60%),
              radial-gradient(60% 60% at 80% 20%, rgba(229,9,20,.10), transparent 55%);
  pointer-events:none;
  filter: blur(0px);
}
.price-card *{ position: relative; }

.price-card .price, .price-card .amount, .price-card .pricing-amount{
  font-size: 44px !important;
  letter-spacing: -0.02em;
  text-shadow: 0 14px 45px rgba(229,9,20,.16);
}
.price-card .sub, .price-card .per, .price-card .pricing-per{
  opacity:.9;
  font-weight: 800;
}
.price-card .badges, .price-card .chips, .price-card .pricing-chips{
  display:flex; gap:10px; flex-wrap:wrap; justify-content:center;
}
.price-card .badge, .price-card .chip{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 999px;
  padding: 8px 10px;
  font-weight: 800;
}
@media (max-width: 560px){
  .price-card .price, .price-card .amount, .price-card .pricing-amount{ font-size: 38px !important; }
}

.compare-section .compare-wrap{
  padding: 22px 18px;
  background: rgba(0,0,0,.55);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 22px 90px rgba(0,0,0,.65), 0 0 0 1px rgba(229,9,20,.08) inset;
  overflow:hidden;
}
.compare-section .compare-wrap::before{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius: 24px;
  background: radial-gradient(65% 55% at 18% 10%, rgba(229,9,20,.18), transparent 62%),
              radial-gradient(60% 60% at 82% 20%, rgba(229,9,20,.10), transparent 60%);
  pointer-events:none;
}
.compare-wrap{ position:relative; }
.compare-wrap *{ position:relative; }

.compare-brand{
  font-weight: 1000;
  letter-spacing: .06em;
  color: var(--netflix-red);
  text-shadow: 0 16px 55px rgba(229,9,20,.18);
  font-size: 40px;
  line-height: 1;
}
.compare-title{
  margin-top: 10px;
  font-size: 28px;
  font-weight: 950;
  line-height: 1.15;
}
.compare-sub{
  margin-top: 8px;
  opacity: .9;
  font-weight: 850;
  font-size: 18px;
}
.compare-note{
  margin-top: 6px;
  opacity: .78;
  font-style: italic;
  text-decoration: underline;
  text-decoration-thickness: 1px;
}
.compare-kicker{
  margin: 22px 0 12px 0;
  font-weight: 950;
  letter-spacing: .08em;
  text-align:center;
  opacity:.95;
}
.compare-disclaimer{
  margin: -6px auto 14px auto;
  max-width: 560px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid rgba(229,9,20,.35);
  background: rgba(0,0,0,.35);
  border-radius: 14px;
  text-align: center;
  font-size: 12px;
  line-height: 1.35;
  color: rgba(255,255,255,.88);
  opacity: 1;
}
.compare-disclaimer .disclaimer-icon{
  color: rgba(229,9,20,1);
  filter: drop-shadow(0 10px 25px rgba(229,9,20,.22));
}
.compare-disclaimer .disclaimer-icon{
  filter: drop-shadow(0 10px 25px rgba(229,9,20,.25));
}
.compare-table{
  border-top: 2px solid rgba(229,9,20,.55);
  border-bottom: 2px solid rgba(229,9,20,.55);
  border-radius: 14px;
  overflow:hidden;
}
.trow{
  display:grid;
  grid-template-columns: 2.2fr .8fr 1fr 1fr;
  gap: 0;
  padding: 14px 12px;
  border-top: 1px solid rgba(229,9,20,.35);
  background: rgba(255,255,255,.02);
}
.trow.thead{
  border-top:none;
  background: rgba(255,255,255,.03);
  font-weight: 950;
}
.trow:hover{ background: rgba(229,9,20,.06); }
.tcell{ font-weight: 800; }
.tcell.center{ text-align:center; }
.tcell.right{ text-align:right; }

/* Cantidad: sin números ni indicadores (columna vacía) */
.tcell.qty{ position: relative; }
.tcell.qty::before{ content: none; display: none; }

.trow.ttotal{
  background: rgba(0,0,0,.35);
  border-top: 1px solid rgba(229,9,20,.5);
}
.compare-footnote{
  margin-top: 18px;
  font-weight: 950;
  text-align:center;
  color: rgba(255,204,0,.92);
  text-shadow: 0 14px 45px rgba(255,204,0,.12);
  letter-spacing: .02em;
}
@media (max-width: 560px){
  .compare-brand{ font-size: 34px; }
  .compare-title{ font-size: 22px; }
  .compare-sub{ font-size: 16px; }
  .trow{ grid-template-columns: 1.5fr .7fr .9fr .9fr; padding: 12px 10px; }
  .tcell{ font-size: 13px; }
}

/* ===== v15.7 refine comparativa colors (remove yellow) ===== */
.compare-note{
  text-decoration: none !important;
  font-style: normal !important;
  opacity: .84 !important;
  color: rgba(255,255,255,.78) !important;
}

.trow.thint{
  border-top:none !important;
  background: rgba(255,255,255,.03) !important;
  font-weight: 950 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase;
}

.compare-table{
  border-top: 1px solid rgba(229,9,20,.55) !important;
  border-bottom: 1px solid rgba(229,9,20,.55) !important;
}

.trow{
  border-top: 1px solid rgba(255,255,255,.06) !important;
}

.trow:hover{
  background: rgba(229,9,20,.08) !important;
}

.compare-footnote{
  margin-top: 18px;
  font-weight: 900;
  text-align:center;
  color: rgba(255,255,255,.88) !important;
  text-shadow: 0 16px 50px rgba(229,9,20,.10);
}
.compare-footnote-strong{
  color: rgba(229,9,20,.92);
  text-shadow: 0 18px 55px rgba(229,9,20,.22);
  font-weight: 1000;
}

.compare-kicker{
  color: rgba(255,255,255,.92);
  text-shadow: 0 18px 55px rgba(0,0,0,.55);
}

.compare-wrap{
  background: rgba(0,0,0,.62) !important;
}

.compare-title{
  text-shadow: 0 18px 60px rgba(0,0,0,.65);
}

.compare-sub{
  color: rgba(255,255,255,.86);
}

/* ===== v15.8 remove price-card frame on mobile ===== */
.price-card{
  border: none !important;
  background: rgba(255,255,255,.03) !important;
  box-shadow: 0 18px 70px rgba(0,0,0,.55) !important;
}
.price-card::before{ opacity: .8 !important; }

.compare-footnote.info-note{
  margin-top: 16px;
  font-size: 12px;
  line-height: 1.35;
  opacity: .85;
  text-align: left;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
  background: rgba(255,255,255,.03);
}
.compare-footnote.info-note .info-dot{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:18px;height:18px;
  border-radius:999px;
  margin-right:8px;
  font-weight: 1000;
  color: rgba(0,0,0,.92);
  background: rgba(255,255,255,.82);
}

/* ===== v15.9 mini headers for mes/año ===== */
.trow.thead-mini{
  background: rgba(255,255,255,.03);
  border-top: 1px solid rgba(229,9,20,.45);
}
.trow.thead-mini .minihead{
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  opacity: .8;
}


/* --- Header fine-tuning (mobile proportions) --- */
@media (max-width: 520px){
  .brand-sub{ font-size: 9px; letter-spacing: .10em; opacity: .85; }
  .btn-nav{ height: 28px; padding: 0 11px; font-size: 10.5px; }
}

