﻿:root {
  --bg: #030303;
  --bg-2: #090909;
  --surface: rgba(255, 255, 255, 0.045);
  --surface-solid: #111111;
  --line: rgba(255, 255, 255, 0.12);
  --line-strong: rgba(255, 255, 255, 0.24);
  --text: #f5f3f2;
  --muted: #9b9694;
  --red: #ff321f;
  --red-bright: #ff5a3d;
  --red-dark: #7f100a;
  --green: #8ae6b0;
  --radius: 20px;
  --radius-lg: 32px;
  --container: 1280px;
  --shadow: 0 30px 80px rgba(0, 0, 0, 0.45);
  --glow: 0 0 60px rgba(255, 50, 31, 0.22);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 90px; }
body {
  margin: 0;
  overflow-x: hidden;
  background: var(--bg);
  color: var(--text);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.55;
}
body.menu-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button { font: inherit; }
img { display: block; max-width: 100%; }
.container { width: min(calc(100% - 36px), var(--container)); margin-inline: auto; }
.skip-link { position: fixed; left: 12px; top: 12px; z-index: 1000; padding: 10px 16px; transform: translateY(-150%); border-radius: 999px; background: #fff; color: #000; }
.skip-link:focus { transform: none; }
:focus-visible { outline: 3px solid rgba(255, 81, 61, 0.7); outline-offset: 3px; }

/* Floating capsule navigation */
.site-header { position: fixed; inset: 0 0 auto; z-index: 100; padding: 14px 0; transition: background 0.3s ease; }
.site-header.scrolled, .site-header.nav-open { background: rgba(3, 3, 3, 0.82); border-bottom: 1px solid var(--line); backdrop-filter: blur(18px); }
.nav-wrap { display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.brand { display: inline-flex; align-items: center; gap: 10px; font-size: 0.95rem; font-weight: 760; letter-spacing: -0.03em; }
.brand b { color: var(--red); }
.brand-mark { display: grid; place-items: center; width: 34px; height: 34px; border: 1px solid rgba(255, 81, 61, 0.6); border-radius: 50%; background: radial-gradient(circle at 40% 40%, var(--red-bright), var(--red-dark)); box-shadow: 0 0 22px rgba(255, 50, 31, 0.35); color: #fff; }
.brand-logo { display: block; height: 52px; width: auto; }
.guide-header .brand-logo, .site-footer .brand-logo { height: 44px; }
.menu-toggle { display: grid; gap: 5px; width: 44px; height: 44px; padding: 12px; cursor: pointer; border: 1px solid var(--line); border-radius: 50%; background: #111; }
.menu-toggle span { height: 2px; border-radius: 2px; background: var(--text); }
.menu-toggle[aria-expanded="true"] span:first-child { transform: translateY(7px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.menu-toggle[aria-expanded="true"] span:last-child { transform: translateY(-7px) rotate(-45deg); }
.site-nav { position: fixed; inset: 72px 0 auto; display: flex; visibility: hidden; flex-direction: column; gap: 3px; max-height: calc(100dvh - 72px); overflow: auto; padding: 18px; transform: translateY(-120%); border-bottom: 1px solid var(--line); background: rgba(3, 3, 3, 0.98); }
.site-header .site-nav.open { visibility: visible !important; transform: none !important; }
.site-nav > a { padding: 10px 12px; border-radius: 999px; color: #c9c5c3; font-size: 0.83rem; }
.site-nav > a:hover { color: #fff; background: rgba(255, 255, 255, 0.06); }
.site-nav > a:first-child { color: #fff; background: var(--red); }
.nav-actions { display: flex; align-items: center; gap: 9px; margin-top: 12px; }
.nav-actions > * { flex: 1; text-align: center; }
.text-link { color: var(--red-bright) !important; }

.button { display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-height: 49px; padding: 0 22px; border: 1px solid transparent; border-radius: 999px; background: var(--red); color: #fff; box-shadow: 0 12px 35px rgba(255, 50, 31, 0.24); font-size: 0.82rem; font-weight: 800; transition: transform 0.2s ease, box-shadow 0.2s ease; }
.button:hover { transform: translateY(-2px); box-shadow: var(--glow); }
.button-small { min-height: 38px; padding: 0 16px; }
.button-ghost { border-color: var(--line-strong); background: rgba(255, 255, 255, 0.05); box-shadow: none; backdrop-filter: blur(12px); }
.button-light { background: #fff; color: #111; box-shadow: 0 12px 35px rgba(255, 255, 255, 0.12); }

/* Hero */
.hero { position: relative; min-height: 970px; overflow: hidden; padding: 145px 0 155px; background: radial-gradient(circle at 76% 35%, rgba(255, 50, 31, 0.18), transparent 36%), #030303; }
.hero::after { position: absolute; inset: auto 0 0; z-index: 2; height: 220px; background: linear-gradient(transparent, var(--bg)); content: ""; pointer-events: none; }
.hero-stars { position: absolute; inset: 0; opacity: 0.22; background-image: radial-gradient(circle, rgba(255,255,255,.55) 0.6px, transparent 0.8px); background-size: 95px 95px; mask-image: linear-gradient(#000, transparent 88%); }
.hero-media { position: absolute; z-index: 1; top: 82px; right: 0; width: 100vw; margin: 0; aspect-ratio: 1672 / 941; filter: saturate(1.06) contrast(1.03); }
.hero-media picture { display: block; width: 100%; height: 100%; }
.hero-media::after { position: absolute; inset: -2px; background: linear-gradient(90deg, #030303 0%, #030303 18%, rgba(3,3,3,.9) 34%, rgba(3,3,3,.38) 50%, transparent 65%, transparent 90%, #030303 100%), linear-gradient(0deg, #030303 0%, transparent 25%); content: ""; pointer-events: none; }
.hero-image { width: 100%; max-width: 100%; height: auto; object-fit: cover; box-shadow: 0 30px 90px rgba(127, 16, 10, .26); }
.hero-content { position: relative; z-index: 4; text-align: left; }
.eyebrow { display: inline-flex; align-items: center; gap: 8px; margin: 0 0 18px; padding: 7px 12px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.035); color: #d8d3d1; font-size: 0.64rem; font-weight: 760; letter-spacing: 0.12em; text-transform: uppercase; }
.eyebrow::before { width: 6px; height: 6px; border-radius: 50%; background: var(--red); box-shadow: 0 0 10px var(--red); content: ""; }
.hero h1 { max-width: 760px; margin: 0; font-size: clamp(3rem, 5.7vw, 5.5rem); line-height: 0.9; letter-spacing: -0.065em; font-weight: 520; }
.hero h1 span, .section-heading h2 span { color: var(--red); }
.hero-tagline { margin: 18px 0 0; color: var(--red-bright); font-size: clamp(1rem, 1.5vw, 1.3rem); font-weight: 700; }
.hero-copy { max-width: 550px; margin: 14px 0 0; color: #b4afad; font-size: clamp(0.93rem, 1.4vw, 1.08rem); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 28px; }
.micro-proof { color: #8a8583; font-size: 0.72rem; }
.micro-proof span { color: var(--green); font-size: 0.52rem; }
.hero-metrics { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; max-width: 620px; margin-top: 42px; }
.hero-metrics > div { min-height: 120px; padding: 18px; border: 1px solid var(--line); border-radius: 18px; background: rgba(9,9,9,.64); backdrop-filter: blur(14px); }
.hero-metrics small { display: block; color: var(--muted); font-size: 0.64rem; }
.hero-metrics strong { display: block; margin-top: 25px; font-size: clamp(1.8rem, 5vw, 3rem); line-height: 1; letter-spacing: -0.06em; font-weight: 520; }
.hero-metrics strong span { color: var(--red); }
.hero-signal-card { display: none; }
.hero-flags { position: absolute; z-index: 6; right: 0; bottom: 30px; left: 0; text-align: center; }
.flags-list { display: flex; justify-content: center; gap: 8px; flex-wrap: wrap; }
.flags-list span { display: inline-flex; align-items: center; gap: 8px; padding: 7px 11px; border: 1px solid var(--line); border-radius: 999px; background: rgba(8, 8, 8, .78); color: #d3cfcd; font-size: .66rem; backdrop-filter: blur(12px); }
.flags-list img { display: block; width: 18px; height: 18px; object-fit: contain; object-position: center; border-radius: 50%; box-shadow: 0 0 0 1px rgba(255,255,255,.08); }
.hero-flags p { margin: 9px 0 0; color: var(--red-bright); font-size: .68rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }

/* Global sections */
.section, .preview-section { padding: clamp(80px, 11vw, 140px) 0; }
.section-alt { border-block: 1px solid rgba(255,255,255,.07); background: #080808; }
.section-heading { max-width: 760px; margin-bottom: 44px; }
.section-heading h2 { margin: 0; font-size: clamp(2.25rem, 6vw, 5.35rem); line-height: .94; letter-spacing: -.06em; font-weight: 500; }
.section-heading > p:not(.eyebrow) { margin: 20px 0 0; color: var(--muted); }
.centered { margin-inline: auto; text-align: center; }
.centered .eyebrow { margin-inline: auto; }
.heading-row > p { max-width: 390px; }
.inline-link { display: inline-flex; gap: 12px; margin-top: 24px; color: var(--red-bright); font-size: .84rem; font-weight: 800; }

/* Entertainment directory */
.preview-section { position: relative; overflow: hidden; background: radial-gradient(circle at 0 45%, rgba(255,69,26,.08), transparent 28%), #050505; }
.category-showcase { display: grid; gap: 14px; align-items: start; }
.category-feature { position: relative; min-height: 400px; overflow: hidden; border: 1px solid rgba(255,69,26,.45); border-radius: 32px; background: #111; box-shadow: 0 26px 70px rgba(0,0,0,.48); }
.category-feature::after { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.04) 25%, rgba(0,0,0,.92) 100%), linear-gradient(90deg, rgba(255,69,26,.18), transparent 48%); content: ""; }
.category-feature > img { width: 100%; height: 100%; position: absolute; inset: 0; object-fit: cover; object-position: center; filter: saturate(.8) contrast(1.08); transition: transform .55s ease; }
.category-feature-copy { position: absolute; z-index: 1; right: 22px; bottom: 22px; left: 22px; display: grid; grid-template-columns: auto 1fr; align-items: end; gap: 16px; }
.category-number { color: #ff451a; font-size: .7rem; font-weight: 900; letter-spacing: .12em; }
.category-feature .category-number { display: grid; place-items: center; width: 50px; height: 50px; border: 1px solid rgba(255,69,26,.65); border-radius: 50%; background: rgba(8,8,8,.72); }
.category-feature small, .category-row small { color: #ff7657; font-size: .61rem; font-weight: 850; letter-spacing: .16em; text-transform: uppercase; }
.category-feature h3 { margin: 4px 0 8px; font-size: clamp(2rem, 6.5vw, 3.6rem); line-height: .9; letter-spacing: -.065em; font-weight: 520; }
.category-feature p { max-width: 420px; margin: 0; color: #d0cbc8; font-size: .79rem; }
.category-directory { display: grid; overflow: hidden; border: 1px solid var(--line); border-radius: 32px; background: #0b0b0b; }
.category-row { position: relative; display: grid; width: 100%; grid-template-columns: 72px 24px 1fr; align-items: center; gap: 14px; min-height: 100px; padding: 12px; overflow: hidden; border: 0; border-bottom: 1px solid var(--line); background: transparent; color: inherit; font: inherit; text-align: left; cursor: pointer; outline: 0; transition: background .22s ease, padding-left .22s ease, box-shadow .22s ease; }
.category-row:last-child { border-bottom: 0; }
.category-row img { width: 72px; height: 72px; border-radius: 16px; object-fit: cover; filter: saturate(.65) brightness(.7); transition: filter .22s ease, transform .22s ease; }
.category-row h3 { margin: 2px 0 4px; font-size: 1.06rem; letter-spacing: -.035em; }
.category-row p { margin: 0; color: var(--muted); font-size: .7rem; line-height: 1.4; }
.category-feature:hover > img { transform: scale(1.025); }
.category-row:hover, .category-row:focus-visible, .category-row.is-active { padding-left: 18px; background: linear-gradient(90deg, rgba(255,69,26,.18), rgba(255,255,255,.025)); box-shadow: inset 4px 0 #ff451a; }
.category-row:hover img, .category-row:focus-visible img, .category-row.is-active img { filter: saturate(.95) brightness(.9); transform: scale(1.03); }
.category-row:focus-visible { box-shadow: inset 4px 0 #ff451a, inset 0 0 0 2px rgba(255,69,26,.72); }
.category-feature.preview-updated > img { animation: category-preview-image .42s ease both; }
.category-feature.preview-updated .category-feature-copy { animation: category-preview-copy .38s ease both; }
@keyframes category-preview-image { from { opacity: .35; transform: scale(1.04); } to { opacity: 1; transform: scale(1); } }
@keyframes category-preview-copy { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }
.benefits-grid { display: grid; gap: 12px; }
.feature-card { display: flex; align-items: center; gap: 16px; min-height: 156px; padding: 20px; border: 1px solid var(--line); border-radius: var(--radius); background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02)); transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease; }
.feature-card:hover { transform: translateY(-5px); border-color: rgba(255,81,61,.52); }
.feature-icon-box { display: grid; place-items: center; width: 64px; height: 64px; flex: 0 0 64px; border: 1px solid rgba(255,74,10,.45); border-radius: 18px; color: #ff4a0a; background: radial-gradient(circle at 50% 50%, rgba(255, 74, 10, 0.08), rgba(10, 10, 10, 0.96) 68%); box-shadow: inset 0 0 20px rgba(255, 74, 10, 0.025), 0 14px 34px rgba(0, 0, 0, 0.35); }
.feature-icon { display: block; width: 32px; height: 32px; object-fit: contain; transition: transform 180ms ease, filter 180ms ease; }
.card-link { color: #ff8c78; text-decoration: underline; text-underline-offset: 3px; }
.feature-copy { min-width: 0; }
.feature-card:hover .feature-icon-box { border-color: rgba(255, 74, 10, 0.75); box-shadow: inset 0 0 22px rgba(255, 74, 10, 0.045), 0 0 24px rgba(255, 74, 10, 0.1); }
.feature-card:hover .feature-icon { transform: scale(1.06); }
.feature-card h3, .detail-card h3 { margin: 0; font-size: 1rem; font-weight: 650; }
.feature-card p, .detail-card p { margin: 8px 0 0; color: var(--muted); font-size: .82rem; }
.steps { display: grid; gap: 12px; padding: 0; list-style: none; }
.step-card { position: relative; min-height: 240px; padding: 24px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); }
.step-card > span { display: grid; place-items: center; width: 58px; height: 58px; margin-bottom: 54px; border: 1px solid rgba(255,81,61,.34); border-radius: 50%; background: linear-gradient(180deg, rgba(255,81,61,.14), rgba(255,81,61,.06)); color: #ff6a52; font-size: 1.18rem; font-weight: 900; letter-spacing: .05em; box-shadow: inset 0 0 0 1px rgba(255,255,255,.04), 0 12px 28px rgba(255,50,31,.08); }
.step-card h3 { margin: 0; font-size: 1.08rem; }
.step-card p { margin: 8px 0 0; color: var(--muted); font-size: .82rem; }
.device-layout { display: grid; gap: 42px; }
.device-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; padding: 0; margin: 0; list-style: none; }
.device-card { display: flex; align-items: center; justify-content: center; gap: 12px; min-height: 76px; padding: 12px 16px; border: 1px solid var(--line); border-radius: 22px; background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025)); color: #f1eeec; box-shadow: inset 0 1px 0 rgba(255,255,255,.05); transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease, background .22s ease; }
.device-card:hover { transform: translateY(-2px); border-color: rgba(255,81,61,.6); background: linear-gradient(180deg, rgba(255,81,61,.09), rgba(255,255,255,.03)); box-shadow: 0 0 0 1px rgba(255,81,61,.15), 0 18px 40px rgba(255,50,31,.12); }
.device-icon { display: grid; place-items: center; width: 40px; height: 40px; flex: 0 0 40px; background: transparent; border-radius: 0; box-shadow: none; overflow: hidden; }
.device-icon img { width: 100%; height: 100%; object-fit: contain; opacity: .98; }
.device-label { font-size: .78rem; font-weight: 750; letter-spacing: -.01em; text-align: center; }

/* Pricing */
.pricing-section { position: relative; overflow: hidden; }
.pricing-glow { position: absolute; top: 160px; left: 50%; width: 760px; height: 470px; border-radius: 50%; background: rgba(127,16,10,.24); filter: blur(110px); transform: translateX(-50%); }
.pricing-tabs { position: relative; z-index: 2; display: flex; width: max-content; margin: 0 auto 40px; padding: 5px; border: 1px solid var(--line); border-radius: 999px; background: #0c0c0c; }
.pricing-tabs button { min-width: 118px; padding: 10px 18px; cursor: pointer; border: 0; border-radius: 999px; background: transparent; color: var(--muted); font-size: .78rem; font-weight: 800; }
.pricing-tabs button[aria-selected="true"] { background: var(--red); color: #fff; }
.pricing-grid { position: relative; display: grid; gap: 12px; }
.price-card { position: relative; padding: 27px 23px; border: 1px solid var(--line); border-radius: var(--radius); background: rgba(13,13,13,.9); box-shadow: var(--shadow); }
.price-card.featured { border-color: rgba(255,81,61,.75); background: linear-gradient(155deg, rgba(113,13,8,.72), #111 58%); box-shadow: var(--glow); }
.plan-badge { position: absolute; right: 18px; top: 18px; padding: 5px 9px; border-radius: 999px; background: var(--red); color: #fff; font-size: .58rem; font-weight: 800; text-transform: uppercase; }
.plan-duration { margin: 0; color: var(--muted); font-size: .66rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.price-card h3 { margin: 6px 0 24px; font-size: 1.1rem; }
.price-line { display: flex; align-items: flex-end; gap: 9px; }
.price { font-size: 3rem; font-weight: 520; line-height: 1; letter-spacing: -.07em; }
.was-price { color: #686260; font-size: .8rem; text-decoration: line-through; }
.price-equivalent { margin: 8px 0 23px; color: var(--muted); font-size: .72rem; }
.price-card .button { width: 100%; }
.plan-features { display: grid; gap: 9px; margin: 24px 0 0; padding: 22px 0 0; border-top: 1px solid var(--line); color: #b9b4b2; font-size: .73rem; list-style: none; }
.plan-features li { position: relative; padding-left: 22px; }
.plan-features li::before { position: absolute; left: 0; top: 0.2em; width: 14px; height: 14px; background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none'%3E%3Cpath d='M13.5 4.2 6.7 11 2.5 6.8' stroke='%23FF451A' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat; content: ""; }
.payment-row { position: relative; display: grid; justify-items: center; gap: 16px; margin-top: 38px; }
.payment-label { margin: 0; color: #807a78; font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; }
.payment-logos { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 12px; }
.payment-logos span { display: inline-flex; align-items: center; justify-content: center; min-width: 104px; min-height: 44px; padding: 10px 14px; border: 1px solid var(--line); border-radius: 16px; background: rgba(255,255,255,.03); }
.payment-logos img { display: block; max-width: 92px; width: auto; max-height: 36px; object-fit: contain; }
.pricing-seo-copy { position: relative; max-width: 760px; margin-top: 34px; color: var(--muted); font-size: .86rem; text-align: center; }

/* Search-focused educational sections */
.seo-split { display: grid; gap: 38px; align-items: start; }
.seo-checklist, .best-checklist { display: grid; gap: 10px; margin: 0; padding: 0; list-style: none; }
.seo-checklist li { display: grid; gap: 5px; padding: 22px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); }
.seo-checklist strong { font-size: .92rem; }
.seo-checklist span { color: var(--muted); font-size: .8rem; }
.best-iptv-section { border-block: 1px solid rgba(255,255,255,.07); background: radial-gradient(circle at 76% 40%, rgba(255,50,31,.1), transparent 32%), #070404; }
.best-checklist { grid-template-columns: 1fr; }
.best-checklist li { position: relative; min-height: 84px; padding: 20px 16px 16px 42px; border: 1px solid var(--line); border-radius: 16px; background: rgba(255,255,255,.035); color: #d8d3d1; font-size: .78rem; }
.best-checklist li::before { position: absolute; left: 16px; top: 18px; display: grid; place-items: center; width: 20px; height: 20px; border-radius: 50%; background: rgba(255,81,61,.12); color: var(--red-bright); content: "✓"; font-size: .72rem; font-weight: 900; line-height: 1; }

/* Stats, details, testimonials, FAQ */
.stats-section { padding: 25px 0 clamp(80px, 10vw, 130px); }
.stats-grid { display: grid; grid-template-columns: repeat(2, 1fr); overflow: hidden; border: 1px solid var(--line-strong); border-radius: var(--radius-lg); background: #080808; }
.stat { padding: 30px 14px; border: 1px solid rgba(255,255,255,.06); text-align: center; }
.stat strong { font-size: clamp(2rem, 6vw, 4.5rem); font-weight: 480; letter-spacing: -.07em; }
.stat strong span { color: var(--red); }
.stat p { margin: 4px 0 0; color: var(--muted); font-size: .66rem; }
.detail-grid { display: grid; grid-template-columns: minmax(0, 1fr); gap: 12px; }
.detail-grid > .feature-card { grid-column: auto; min-width: 0; }
.detail-card { min-height: 156px; }
.testimonials-grid { display: grid; gap: 12px; }
.testimonial { margin: 0; padding: 25px; border: 1px solid var(--line); border-radius: var(--radius); background: #0d0d0d; }
.stars { color: var(--red-bright); font-size: .7rem; letter-spacing: .14em; }
.stars span { color: #4c4745; }
.testimonial blockquote { margin: 20px 0 28px; color: #dad6d4; font-size: .85rem; }
.testimonial figcaption { display: flex; align-items: center; gap: 11px; }
.testimonial figcaption > span { display: grid; place-items: center; width: 38px; height: 38px; border: 1px solid rgba(255,81,61,.45); border-radius: 50%; background: #270907; font-size: .66rem; font-weight: 800; }
.testimonial figcaption div { display: grid; }
.testimonial figcaption b { font-size: .76rem; }
.testimonial figcaption small { color: var(--muted); font-size: .63rem; }
.faq-layout { display: grid; gap: 38px; }
.accordion { border-top: 1px solid var(--line); }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-item h3 { margin: 0; }
.faq-item button { display: flex; justify-content: space-between; align-items: center; width: 100%; padding: 22px 0; cursor: pointer; border: 0; background: transparent; color: var(--text); text-align: left; font-weight: 700; }
.faq-item button span { display: grid; place-items: center; flex: 0 0 30px; height: 30px; margin-left: 18px; border: 1px solid var(--line); border-radius: 50%; color: var(--red-bright); }
.faq-answer { padding: 0 42px 21px 0; }
.faq-answer p { margin: 0; color: var(--muted); font-size: .84rem; }

.reseller-card { position: relative; display: grid; gap: 30px; overflow: hidden; padding: 40px 28px; border: 1px solid rgba(255,81,61,.55); border-radius: var(--radius-lg); background: radial-gradient(circle at 82% 24%, rgba(255,81,61,.38), transparent 25%), linear-gradient(125deg, #3a0805, #b11b10 60%, #410805); box-shadow: var(--glow); }
.reseller-card::after { position: absolute; right: -100px; bottom: -230px; width: 520px; height: 520px; border: 1px solid rgba(255,255,255,.16); border-radius: 50%; content: ""; }
.reseller-card > * { position: relative; z-index: 1; }
.reseller-card h2 { max-width: 700px; margin: 0; font-size: clamp(2.3rem, 6vw, 5rem); line-height: .94; letter-spacing: -.06em; font-weight: 500; }
.reseller-card p:not(.eyebrow) { max-width: 650px; color: #f2cfcb; }
.reseller-card .eyebrow { color: #fff; }

.site-footer { padding: 72px 0 24px; border-top: 1px solid var(--line); background: #020202; }
.footer-grid { display: grid; gap: 38px; }
.footer-grid > div { display: flex; flex-direction: column; align-items: flex-start; gap: 8px; }
.footer-grid > div:first-child p { max-width: 340px; color: var(--muted); font-size: .82rem; }
.footer-grid h2 { margin: 0 0 8px; color: #fff; font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; }
.footer-grid > div:not(:first-child) a { color: var(--muted); font-size: .76rem; }
.footer-grid a:hover { color: var(--red-bright); }
.footer-grid small { color: #66615f; }
.footer-bottom { display: flex; justify-content: center; align-items: center; text-align: center; gap: 12px; margin-top: 50px; padding-top: 20px; border-top: 1px solid var(--line); color: #625d5b; font-size: .64rem; }
.footer-bottom a { color: #ff9c8b; }

/* Floating shortcut to pricing */
.plans-shortcut {
  position: fixed;
  left: max(18px, env(safe-area-inset-left));
  bottom: max(18px, env(safe-area-inset-bottom));
  z-index: 94;
  display: flex;
  flex-direction: column;
  gap: 3px;
  width: min(240px, calc(100vw - 102px));
  padding: 14px 18px;
  border: 1px solid rgba(255, 90, 61, .42);
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(255, 69, 26, .16), rgba(15, 15, 15, .96) 62%);
  box-shadow: 0 14px 40px rgba(0, 0, 0, .46), 0 0 28px rgba(255, 69, 26, .12);
  backdrop-filter: blur(14px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(18px);
  transition: opacity .24s ease, transform .24s ease, border-color .2s ease, box-shadow .2s ease;
}
.plans-shortcut::before {
  position: absolute;
  inset: -4px;
  z-index: -1;
  border: 1px solid rgba(255, 90, 61, .16);
  border-radius: inherit;
  content: "";
}
.plans-shortcut strong {
  display: block;
  color: #fff;
  font-size: .8rem;
  font-weight: 820;
  letter-spacing: -.02em;
}
.plans-shortcut span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #ff9f8c;
  font-size: .68rem;
  font-weight: 760;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.plans-shortcut i { font-style: normal; }
.plans-shortcut.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: none;
}
.plans-shortcut:hover,
.plans-shortcut:focus-visible {
  border-color: rgba(255, 90, 61, .7);
  box-shadow: 0 18px 46px rgba(0, 0, 0, .54), 0 0 34px rgba(255, 69, 26, .24);
}

/* Floating WhatsApp contact */
.whatsapp-float {
  position: fixed;
  right: max(18px, env(safe-area-inset-right));
  bottom: max(18px, env(safe-area-inset-bottom));
  z-index: 95;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 62px;
  height: 62px;
  border: 1px solid rgba(37, 211, 102, .58);
  border-radius: 50%;
  background: rgba(7, 18, 11, .94);
  box-shadow: 0 12px 36px rgba(0, 0, 0, .5), 0 0 28px rgba(37, 211, 102, .24);
  backdrop-filter: blur(12px);
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.whatsapp-float::before {
  position: absolute;
  inset: -5px;
  z-index: -1;
  border: 1px solid rgba(37, 211, 102, .22);
  border-radius: inherit;
  content: "";
}
.whatsapp-float img { width: 38px; height: 38px; object-fit: contain; }
.whatsapp-float span {
  position: absolute;
  right: calc(100% + 11px);
  padding: 7px 11px;
  transform: translateX(7px);
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(8, 8, 8, .94);
  color: #fff;
  font-size: .7rem;
  font-weight: 750;
  opacity: 0;
  pointer-events: none;
  white-space: nowrap;
  transition: opacity .2s ease, transform .2s ease;
}
.whatsapp-float:hover,
.whatsapp-float:focus-visible { transform: translateY(-3px) scale(1.04); border-color: #25d366; box-shadow: 0 16px 42px rgba(0, 0, 0, .56), 0 0 34px rgba(37, 211, 102, .38); }
.whatsapp-float:hover span,
.whatsapp-float:focus-visible span { transform: none; opacity: 1; }
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: none; }

/* Best IPTV guide page */
.guide-page { background: #030303; }
.guide-header { position: sticky; top: 0; z-index: 50; padding: 14px 0; border-bottom: 1px solid var(--line); background: rgba(3,3,3,.88); backdrop-filter: blur(18px); }
.guide-nav { display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.guide-hero { position: relative; overflow: hidden; padding: clamp(100px, 13vw, 170px) 0 clamp(80px, 10vw, 130px); background: radial-gradient(circle at 78% 35%, rgba(255,50,31,.16), transparent 32%), #030303; }
.guide-hero-grid { display: grid; gap: 42px; align-items: center; }
.guide-hero h1 { max-width: 850px; margin: 0; font-size: clamp(2.8rem, 7vw, 6.3rem); line-height: .9; letter-spacing: -.065em; font-weight: 520; }
.guide-hero p:not(.eyebrow) { max-width: 650px; margin: 24px 0 0; color: #aaaeb9; }
.guide-hero img { width: 100%; height: auto; border-radius: var(--radius-lg); box-shadow: 0 30px 90px rgba(127,16,10,.28); }
.guide-card-grid { display: grid; gap: 12px; }
.guide-card-grid article { min-height: 210px; padding: 24px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); }
.guide-card-grid article > span { display: block; margin-bottom: 52px; color: var(--red-bright); font-size: .7rem; font-weight: 800; }
.guide-card-grid h3 { margin: 0; font-size: 1rem; }
.guide-card-grid p { margin: 9px 0 0; color: var(--muted); font-size: .82rem; }
.guide-feature { display: grid; gap: 40px; padding: clamp(30px,5vw,70px); border: 1px solid var(--line); border-radius: var(--radius-lg); background: radial-gradient(circle at 80% 20%, rgba(255,50,31,.12), transparent 28%), #0b0706; }
.guide-feature h2 { margin: 0; font-size: clamp(2.2rem,5vw,4.8rem); line-height: .94; letter-spacing: -.055em; font-weight: 520; }
.guide-feature p:not(.eyebrow) { color: var(--muted); }
.guide-feature ul { display: grid; gap: 12px; margin: 0; padding: 0; list-style: none; }
.guide-feature li { padding: 16px 18px; border: 1px solid var(--line); border-radius: 999px; color: #d7dde8; font-size: .8rem; }
.guide-feature li::before { margin-right: 10px; color: var(--red-bright); content: "✓"; }
.guide-page details.faq-item summary { display: flex; justify-content: space-between; align-items: center; padding: 22px 0; cursor: pointer; font-weight: 700; list-style: none; }
.guide-page details.faq-item summary::-webkit-details-marker { display: none; }
.guide-meta { margin-top: 18px; color: #8f8985 !important; font-size: .76rem !important; }
.comparison-table-wrap { overflow-x: auto; border: 1px solid var(--line); border-radius: 24px; background: #090909; }
.comparison-table { width: 100%; min-width: 760px; border-collapse: collapse; color: #b8b2ae; font-size: .84rem; line-height: 1.6; }
.comparison-table th, .comparison-table td { padding: 18px 20px; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; }
.comparison-table thead th { color: #fff; background: rgba(255,69,26,.08); font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; }
.comparison-table tbody th { width: 18%; color: #ff8c78; }
.comparison-table tr:last-child th, .comparison-table tr:last-child td { border-bottom: 0; }
.guide-page details.faq-item summary::after { display: grid; place-items: center; flex: 0 0 30px; height: 30px; margin-left: 18px; border: 1px solid var(--line); border-radius: 50%; color: var(--red-bright); content: "+"; }
.guide-page details.faq-item[open] summary::after { content: "−"; }

/* Legal pages */
.legal-page { min-height: 100vh; background: radial-gradient(circle at 85% 5%, rgba(255,50,31,.1), transparent 26%), #030303; }
.legal-header { position: sticky; top: 0; z-index: 50; padding: 12px 0; border-bottom: 1px solid var(--line); background: rgba(3,3,3,.9); backdrop-filter: blur(18px); }
.legal-header .brand-logo { height: 44px; }
.legal-header-inner { display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.legal-back { display: inline-flex; align-items: center; gap: 8px; padding: 9px 15px; border: 1px solid var(--line); border-radius: 999px; color: #d5d1cf; font-size: .76rem; font-weight: 750; transition: border-color .2s ease, color .2s ease, background .2s ease; }
.legal-back:hover { border-color: rgba(255,90,61,.55); background: rgba(255,50,31,.08); color: #fff; }
.legal-hero { padding: clamp(86px,12vw,150px) 0 clamp(48px,7vw,84px); border-bottom: 1px solid var(--line); }
.legal-hero .eyebrow { margin-bottom: 22px; }
.legal-hero h1 { max-width: 900px; margin: 0; font-size: clamp(3rem,8vw,6.8rem); font-weight: 520; line-height: .9; letter-spacing: -.065em; }
.legal-hero h1 span { color: var(--red-bright); }
.legal-hero-copy { max-width: 720px; margin: 28px 0 0; color: var(--muted); font-size: clamp(.95rem,1.5vw,1.1rem); }
.legal-updated { display: inline-flex; align-items: center; gap: 8px; margin-top: 28px; color: #d0ccca; font-size: .72rem; font-weight: 750; letter-spacing: .08em; text-transform: uppercase; }
.legal-updated::before { width: 7px; height: 7px; border-radius: 50%; background: var(--red); box-shadow: 0 0 14px var(--red); content: ""; }
.legal-layout { display: grid; gap: 44px; padding-block: clamp(52px,8vw,100px); }
.legal-toc { align-self: start; padding: 22px; border: 1px solid var(--line); border-radius: var(--radius); background: rgba(255,255,255,.025); }
.legal-toc strong { display: block; margin-bottom: 14px; color: #fff; font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; }
.legal-toc nav { display: grid; gap: 5px; }
.legal-toc a { padding: 7px 0; color: var(--muted); font-size: .78rem; }
.legal-toc a:hover { color: var(--red-bright); }
.legal-content { min-width: 0; }
.legal-section { scroll-margin-top: 105px; padding: 0 0 42px; margin: 0 0 42px; border-bottom: 1px solid var(--line); }
.legal-section:last-child { margin-bottom: 0; border-bottom: 0; }
.legal-section h2 { margin: 0 0 18px; color: #fff; font-size: clamp(1.5rem,3vw,2.25rem); font-weight: 620; letter-spacing: -.035em; }
.legal-section h3 { margin: 28px 0 10px; color: #eeeae8; font-size: 1rem; }
.legal-section p, .legal-section li { color: #aaa5a2; font-size: .91rem; line-height: 1.8; }
.legal-section p { margin: 0 0 14px; }
.legal-section ul { display: grid; gap: 9px; margin: 16px 0; padding-left: 22px; }
.legal-section li::marker { color: var(--red-bright); }
.legal-section a { color: #ff8c78; text-decoration: underline; text-underline-offset: 3px; }
.legal-note { padding: 20px; border: 1px solid rgba(255,90,61,.28); border-radius: 16px; background: rgba(255,50,31,.055); }
.legal-footer { padding: 28px 0; border-top: 1px solid var(--line); color: #706b68; font-size: .68rem; text-align: center; }
.legal-footer-links { display: flex; flex-wrap: wrap; justify-content: center; gap: 14px 22px; margin-bottom: 13px; }
.legal-footer-links a { color: #aaa5a2; }
.legal-footer-links a:hover { color: var(--red-bright); }

@media (min-width: 600px) {
  .category-showcase { grid-template-columns: minmax(0, .96fr) minmax(0, 1.04fr); }
  .category-feature { min-height: 540px; }
  .benefits-grid, .steps, .pricing-grid, .testimonials-grid, .detail-grid { grid-template-columns: repeat(2, 1fr); }
  .benefits-grid .feature-card:last-child { grid-column: auto; }
  .seo-split { grid-template-columns: .9fr 1.1fr; gap: 50px; }
  .best-checklist { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .device-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .footer-grid { grid-template-columns: 1.5fr 1fr 1fr; }
  .footer-grid > div:last-child { grid-column: 2 / -1; }
  .reseller-card { padding: 56px; }
  .reseller-card .button { width: max-content; }
  .guide-card-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 760px) {
  .detail-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .detail-grid > .feature-card { grid-column: auto; }
}

@media (min-width: 900px) {
  .hero-metrics { display: none; }
  .site-header { padding: 18px 0; }
  .brand { gap: 12px; }
  .menu-toggle { display: none; }
  .site-nav { position: static; display: flex; visibility: visible; flex-direction: row; align-items: center; gap: 3px; max-height: none; margin-left: auto; padding: 5px; transform: none; overflow: visible; border: 1px solid var(--line); border-radius: 999px; background: rgba(8,8,8,.74); backdrop-filter: blur(16px); }
  .site-nav > a { padding: 7px 11px; font-size: .67rem; }
  .nav-actions { margin: 0 0 0 12px; }
  .nav-actions > * { flex: none; }
  .hero { min-height: 980px; padding-top: 180px; }
  .hero-media { top: 82px; right: 0; width: 100vw; }
  .hero-content { padding-right: 48%; }
  .hero-signal-card { position: absolute; z-index: 5; right: max(24px, calc((100vw - var(--container))/2)); top: 270px; display: flex; flex-direction: column; width: 190px; min-height: 230px; padding: 22px; border: 1px solid var(--line-strong); border-radius: 20px; background: rgba(8,8,8,.7); box-shadow: var(--shadow); backdrop-filter: blur(16px); }
  .hero-signal-card small, .hero-signal-card span { color: var(--muted); font-size: .63rem; }
  .hero-signal-card strong { margin-top: 65px; font-size: 2.6rem; line-height: 1; letter-spacing: -.06em; font-weight: 520; }
  .hero-signal-card i { height: 3px; margin-top: 20px; border-radius: 4px; background: linear-gradient(90deg, var(--red) 80%, #3d1714 80%); }
  .hero-flags { right: 0; left: 0; }
  .heading-row { display: flex; align-items: end; justify-content: space-between; max-width: none; }
  .heading-row > div { max-width: 800px; }
  .category-showcase { grid-template-columns: minmax(0, .88fr) minmax(460px, 1.12fr); gap: 18px; }
  .category-feature { min-height: 520px; }
  .category-row { min-height: 104px; grid-template-columns: 72px 24px 1fr; padding: 13px 15px; }
  .category-row img { width: 72px; height: 72px; }
  .benefits-grid { grid-template-columns: repeat(12, 1fr); }
  .feature-card { grid-column: span 4; }
  .feature-card:nth-child(4), .feature-card:nth-child(5), .benefits-grid .feature-card:last-child { grid-column: span 4; }
  .steps { grid-template-columns: repeat(4, 1fr); }
  .device-layout { grid-template-columns: .8fr 1.2fr; align-items: center; }
  .device-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .pricing-grid { grid-template-columns: repeat(4, 1fr); }
  .price-card.featured { transform: translateY(-12px); }
  .stats-grid { grid-template-columns: repeat(4, 1fr); }
  #everything-included .detail-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  #everything-included .detail-grid > .feature-card { grid-column: auto; width: auto; }
  .testimonials-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .faq-layout { grid-template-columns: .8fr 1.2fr; gap: 90px; }
  .reseller-card { grid-template-columns: 1fr auto; align-items: center; }
  .footer-grid { grid-template-columns: 2fr 1fr 1fr 1.3fr; }
  .footer-grid > div:last-child { grid-column: auto; }
  .guide-hero-grid { grid-template-columns: 1.05fr .95fr; }
  .guide-card-grid { grid-template-columns: repeat(3, 1fr); }
  .guide-feature { grid-template-columns: 1.15fr .85fr; align-items: center; }
  .legal-layout { grid-template-columns: minmax(210px, .32fr) minmax(0, 1fr); gap: clamp(55px,8vw,120px); }
  .legal-toc { position: sticky; top: 100px; }
  .plans-shortcut {
    left: max(24px, calc((100vw - var(--container)) / 2));
    bottom: 26px;
    width: 220px;
  }
}

@media (min-width: 1180px) {
  .site-nav > a { padding-inline: 13px; }
  .hero-content { padding-right: 50%; }
}

@media (max-width: 899px) {
  .brand-logo { height: 42px; }
  .guide-header .brand-logo, .site-footer .brand-logo { height: 38px; }
  .hero { min-height: 0; padding-bottom: 36px; }
  .hero-media { position: relative; top: auto; right: auto; width: min(calc(100% - 24px), 680px); margin: 34px auto 0; aspect-ratio: 4 / 3; overflow: hidden; border-radius: 20px; }
  .hero-media::after { background: linear-gradient(0deg, #030303 0%, transparent 22%); }
  .hero-image { height: 100%; object-fit: cover; object-position: 67% center; }
  .hero-content { text-align: left; }
  .hero h1 { font-size: clamp(2.75rem, 11.5vw, 4.3rem); }
  .hero-metrics { grid-template-columns: repeat(3, minmax(102px, 1fr)); width: 100%; overflow-x: auto; }
  .hero-metrics > div { min-height: 105px; padding: 14px; }
  .hero-metrics strong { margin-top: 20px; }
  .hero-flags { position: relative; right: auto; bottom: auto; left: auto; margin-top: 8px; }
  .flags-list { gap: 7px; }
  .flags-list span { padding: 7px 9px; font-size: .61rem; }
  .flags-list img { width: 16px; height: 16px; }
  .device-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 9px; }
  .device-card { min-height: 68px; padding-inline: 12px; }
  .device-label { font-size: .72rem; }
  .footer-bottom { justify-content: center; align-items: center; flex-direction: column; text-align: center; }
  .plans-shortcut {
    left: max(14px, env(safe-area-inset-left));
    bottom: max(14px, env(safe-area-inset-bottom));
    width: min(228px, calc(100vw - 92px));
    padding: 12px 15px;
    border-radius: 18px;
  }
  .plans-shortcut strong { font-size: .76rem; }
  .plans-shortcut span { font-size: .62rem; }
  .whatsapp-float { right: max(14px, env(safe-area-inset-right)); bottom: max(14px, env(safe-area-inset-bottom)); width: 56px; height: 56px; }
  .whatsapp-float img { width: 34px; height: 34px; }
  .whatsapp-float span { display: none; }
  .legal-header .brand-logo { height: 38px; }
  .legal-hero h1 { font-size: clamp(2.8rem,15vw,5rem); }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
  .reveal { opacity: 1; transform: none; }
}
.hero-signal-card { display: none !important; }

