/* ============================================================
   futeaovivo — landing (identidade PIVÔ)
   Broadcast (hero azul + headline gigante) + editorial (creme,
   selos, números de fundo). Cantos retos, bordas pretas pesadas,
   sombras chapadas, rótulos mono. Sem emoji.
   Tokens do design system PIVÔ.
   ============================================================ */
:root {
  --blue: #1A2CF0; --blue-deep: #0C159C; --blue-bright: #4A63FF;
  --black: #0B0B0E; --white: #FFFFFF;
  --red: #FB2C24; --yellow: #FFD200; --green: #15DF6B; --purple: #7B36F0;
  --cream: #F3EAD6; --cream-deep: #E7D7B0;
  --ink-900: #0B0B0E; --ink-700: #25252E; --ink-500: #5A5A68; --ink-300: #A6A6B4; --ink-100: #ECECF1;

  --font-display: 'Archivo', 'Arial Black', system-ui, sans-serif;
  --font-sans: 'IBM Plex Sans', system-ui, -apple-system, sans-serif;
  --font-mono: 'IBM Plex Mono', ui-monospace, 'SFMono-Regular', monospace;

  --fs-mega: clamp(56px, 11vw, 168px);
  --fs-display: clamp(40px, 7vw, 104px);
  --fs-h1: clamp(34px, 5vw, 64px);
  --fs-h2: clamp(26px, 3.4vw, 42px);

  --radius-sm: 3px; --radius-pill: 999px;
  --bw-bold: 3px;
  --shadow-pop-sm: 4px 4px 0 var(--ink-900);
  --shadow-pop: 7px 7px 0 var(--ink-900);
  --shadow-pop-lg: 12px 12px 0 var(--ink-900);
  --ease-out: cubic-bezier(.2,.7,.2,1);
  --ease-snap: cubic-bezier(.2,.9,.25,1.25);
  --container: 1440px;
  --page-pad: clamp(20px, 5vw, 76px);
  --nav-h: 64px;
}

@keyframes fav-pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.35;transform:scale(.7)} }
@keyframes fav-marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes fav-pop { from { transform: rotate(-6deg) scale(.6); opacity: 0; } to { transform: rotate(-6deg) scale(1); opacity: 1; } }

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0; font-family: var(--font-sans); font-size: 17px; line-height: 1.5;
  color: var(--ink-900); background: var(--cream); -webkit-font-smoothing: antialiased;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--yellow); color: var(--ink-900); }

.wrap { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--page-pad); }

/* ---------- type helpers ---------- */
.t-display, .t-h1, .t-h2 {
  font-family: var(--font-display);
  font-variation-settings: 'wdth' 116, 'wght' 850;
  font-weight: 800; text-transform: uppercase; line-height: .92;
  letter-spacing: -.02em; text-wrap: balance; margin: 0;
}
.t-display { font-size: var(--fs-display); }
.t-h1 { font-size: var(--fs-h1); }
.t-h2 { font-size: var(--fs-h2); }
.t-mega { font-family: var(--font-display); font-variation-settings: 'wdth' 118, 'wght' 880; font-weight: 900; text-transform: uppercase; font-size: var(--fs-mega); line-height: .86; letter-spacing: -.03em; margin: 0; }
.t-label { font-family: var(--font-mono); font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: .16em; }
.t-lead { font-size: clamp(17px, 2vw, 21px); line-height: 1.5; }

/* ---------- botão sticker ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  padding: 15px 28px; font-family: var(--font-sans); font-weight: 700; font-size: 15px;
  text-transform: uppercase; letter-spacing: .05em; line-height: 1; cursor: pointer;
  color: var(--white); background: var(--blue);
  border: var(--bw-bold) solid var(--ink-900); border-radius: var(--radius-pill);
  box-shadow: var(--shadow-pop-sm);
  transition: transform 120ms var(--ease-out), box-shadow 120ms var(--ease-out);
}
.btn:hover { transform: translate(-2px,-2px); box-shadow: var(--shadow-pop); }
.btn:active { transform: translate(2px,2px); box-shadow: none; }
.btn.yellow { background: var(--yellow); color: var(--ink-900); }
.btn.light { background: var(--white); color: var(--ink-900); }
.btn.lg { padding: 18px 36px; font-size: 17px; }

/* ---------- tag / live ---------- */
.tag { display: inline-flex; align-items: center; gap: 7px; padding: 6px 13px; font-family: var(--font-mono); font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: .12em; border-radius: var(--radius-pill); background: var(--ink-900); color: #fff; }
.live { background: var(--red); color: #fff; }
.live .dot { width: 9px; height: 9px; border-radius: 50%; background: #fff; animation: fav-pulse 1.1s var(--ease-out) infinite; }

/* ---------- NAV ---------- */
.nav { position: sticky; top: 0; z-index: 50; background: var(--black); border-bottom: var(--bw-bold) solid var(--blue); }
.nav .wrap { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding-block: 14px; }
.brand { display: flex; align-items: center; gap: 10px; }
.brand .mark { width: 36px; height: 36px; flex: none; display: block; }
.brand .wm { font-family: var(--font-display); font-variation-settings: 'wdth' 112, 'wght' 820; font-weight: 800; font-size: 24px; color: #fff; letter-spacing: -.01em; }
.nav-links { display: flex; align-items: center; gap: 26px; }
.nav-links a { font-family: var(--font-mono); font-size: 12px; text-transform: uppercase; letter-spacing: .12em; color: rgba(255,255,255,.72); }
.nav-links a:hover { color: var(--yellow); }
.nav .btn { padding: 10px 18px; font-size: 12px; }

/* ---------- HERO ---------- */
.hero { position: relative; overflow: hidden; background: var(--blue); color: #fff; }
.hero .bgnum { position: absolute; right: -2%; top: 50%; transform: translateY(-50%); font-family: var(--font-display); font-variation-settings: 'wght' 900; font-weight: 900; font-size: clamp(280px, 46vw, 760px); line-height: 1; color: rgba(255,255,255,.07); pointer-events: none; user-select: none; z-index: 0; }
.hero .wrap { position: relative; z-index: 1; min-height: calc(100svh - var(--nav-h)); padding-block: clamp(14px, 2.4vh, 28px); display: grid; grid-template-columns: minmax(0, 1fr) minmax(360px, 0.95fr); grid-template-rows: 1fr auto auto; grid-template-areas: "copy demo" "tl demo" "cta cta"; gap: clamp(24px, 3.4vw, 56px); align-items: stretch; }
.hero-copy { grid-area: copy; align-self: center; }
.hero-media { display: flex; justify-content: center; }
.hero .mascot { width: min(100%, 400px); height: auto; filter: drop-shadow(7px 7px 0 rgba(0,0,0,.4)); }
.hero .eyebrow { display: flex; align-items: center; gap: 12px; margin-bottom: 22px; }
.hero h1 { color: #fff; max-width: 12ch; font-size: clamp(32px, 4.4vw, 72px); line-height: .9; overflow-wrap: break-word; }
.hero h1 .hl { color: var(--yellow); }
.hero p { max-width: 44ch; margin: 18px 0 0; font-size: clamp(15px, 1.5vw, 18px); color: rgba(255,255,255,.9); }
.hero .cta { grid-area: cta; display: flex; flex-wrap: wrap; justify-content: center; gap: 14px; margin-top: 0; }
.hero .spark { position: absolute; color: var(--yellow); z-index: 1; }
.hero .spark.s1 { width: 54px; top: 14%; right: 16%; }
.hero .spark.s2 { width: 30px; bottom: 16%; right: 38%; opacity: .8; }
.hero .note { margin-top: 16px; font-family: var(--font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.6); }

/* ---------- HERO: linha do tempo (lead) ---------- */
.hero .lead-tl { grid-area: tl; align-self: start; margin: 18px 0 0; max-width: 560px; }
.lc-label { display: inline-block; font-family: var(--font-mono); font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: .14em; color: var(--yellow); margin-bottom: 8px; }
.ast { font-weight: 700; }

.tl { position: relative; height: 150px; }
.tl-line { position: absolute; left: 0; right: 0; top: 88px; height: 3px; background: rgba(255,255,255,.30); }
.tl-line::after { content: ''; position: absolute; right: -1px; top: 50%; width: 8px; height: 8px; border-top: 3px solid rgba(255,255,255,.30); border-right: 3px solid rgba(255,255,255,.30); transform: translate(0,-50%) rotate(45deg); }

.tl-pt { position: absolute; left: var(--x); top: 0; width: 0; height: 100%; }
.tl-node { position: absolute; top: 88px; left: 0; transform: translate(-50%,-50%); width: 38px; height: 38px; display: flex; align-items: center; justify-content: center; background: var(--white); color: var(--ink-900); border: var(--bw-bold) solid var(--ink-900); border-radius: 50%; box-shadow: var(--shadow-pop-sm); }
.tl-node svg { width: 21px; height: 21px; }
.tl-cap { position: absolute; top: 116px; left: 0; transform: translateX(-50%); white-space: nowrap; font-family: var(--font-mono); font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .03em; color: rgba(255,255,255,.78); }
.tl-cap.strong { color: #fff; font-weight: 700; }

.is-gol .tl-node { width: 30px; height: 30px; background: var(--yellow); }
.is-gol .tl-node svg { width: 19px; height: 19px; fill: var(--ink-900); }
.is-gol .tl-cap { transform: translateX(-22%); }

.is-fav .tl-node { width: 52px; height: 52px; border-color: var(--blue); box-shadow: 0 0 0 4px rgba(255,255,255,.18), var(--shadow-pop-sm); padding: 6px; }
.is-fav .tl-node img { width: 100%; height: 100%; object-fit: contain; border-radius: 50%; }
.is-fav .tl-cap.strong { font-size: 12px; }

.is-yt .tl-cap { transform: translateX(-80%); }

.tl-brace { position: absolute; left: 25%; right: 10%; top: 42px; height: 24px; border: 3px solid var(--green); border-bottom: 0; border-radius: 9px 9px 0 0; }
.tl-brace-cap { position: absolute; left: 50%; top: -12px; transform: translateX(-50%); white-space: nowrap; background: var(--blue); padding: 2px 9px; font-family: var(--font-mono); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .03em; color: #fff; }
.tl-brace-cap .ast { color: var(--yellow); }

.tl-near { position: absolute; left: 15.5%; top: 58px; transform: translateX(-50%); white-space: nowrap; font-family: var(--font-mono); font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: .03em; color: rgba(255,255,255,.66); }
.tl-near .ast { color: var(--yellow); }

/* nota do asterisco — faixa cheia entre o hero e o ticker */
.fineprint { margin: 0; background: var(--blue); color: rgba(255,255,255,.62); text-align: center; padding: 13px var(--page-pad); font-family: var(--font-mono); font-size: 11px; line-height: 1.5; letter-spacing: .01em; }
.fineprint .ast { color: var(--yellow); font-weight: 700; }

/* ---------- HERO: demo 3 telas (corrida de atraso) ---------- */
.hero-demo { grid-area: demo; position: relative; z-index: 1; display: flex; width: 100%; margin-left: auto; }
.demo-grid { width: 100%; height: 100%; max-height: 100%; display: grid; grid-template-rows: auto minmax(0, 1fr) minmax(0, 1fr); gap: 0; border: var(--bw-bold) solid var(--ink-900); box-shadow: var(--shadow-pop); background: #000; overflow: hidden; }
.feed { display: flex; flex-direction: column; min-height: 0; margin: 0; background: var(--white); overflow: hidden; }
.feed + .feed { border-top: var(--bw-bold) solid var(--ink-900); }
.feed-head { flex: none; display: flex; align-items: center; justify-content: space-between; gap: 8px; padding: 9px 12px; border-bottom: var(--bw-bold) solid var(--ink-900); background: var(--white); }
.feed-tv  .feed-head { box-shadow: inset 0 4px 0 var(--red); }
.feed-fav .feed-head { box-shadow: inset 0 4px 0 var(--blue); }
.feed-yt  .feed-head { box-shadow: inset 0 4px 0 var(--ink-300); }
.feed-name { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-mono); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--ink-900); }
.feed-mark { width: 18px; height: 18px; border-radius: 50%; flex: none; }
.feed-yt-mark { width: 18px; height: auto; flex: none; }
.feed-bar .feed-head { border-bottom: 0; }
.tv-gol { display: none; font-family: var(--font-display); font-variation-settings: 'wght' 900; font-weight: 900; font-size: 15px; text-transform: uppercase; letter-spacing: .01em; line-height: 1; padding: 5px 13px; border: 2.5px solid var(--ink-900); border-radius: 2px; color: var(--ink-900); background: var(--yellow); }
.feed-tv.scored .tv-gol { display: inline-block; animation: tv-pop .25s var(--ease-snap); }
@keyframes tv-pop { from { transform: scale(.6); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.feed-screen { position: relative; flex: 1 1 0; min-height: 0; background: #000; }
.feed-screen video { width: 100%; height: 100%; object-fit: cover; display: block; }
.feed-flag { position: absolute; top: 10px; left: 10px; display: none; transform: rotate(-6deg); font-family: var(--font-display); font-variation-settings: 'wght' 900; font-weight: 900; font-size: clamp(16px, 2.6vh, 30px); line-height: 1; color: var(--ink-900); background: var(--yellow); border: var(--bw-bold) solid var(--ink-900); box-shadow: var(--shadow-pop-sm); padding: 4px 10px; letter-spacing: -.01em; }
.feed.scored .feed-flag { display: block; animation: fav-pop .25s var(--ease-snap); }

/* ---------- TICKER ---------- */
.ticker { overflow: hidden; white-space: nowrap; background: var(--black); color: #fff; border-top: var(--bw-bold) solid var(--ink-900); border-bottom: var(--bw-bold) solid var(--ink-900); padding-block: 12px; }
.ticker .track { display: inline-flex; animation: fav-marquee 30s linear infinite; }
.ticker .grp { display: inline-flex; align-items: center; gap: 22px; padding-right: 22px; flex-shrink: 0; }
.ticker .it { font-family: var(--font-display); font-variation-settings: 'wdth' 110, 'wght' 800; font-weight: 800; text-transform: uppercase; letter-spacing: .02em; font-size: 17px; }
.ticker .sep { color: var(--yellow); }

/* ---------- SECTIONS ---------- */
.section { padding-block: clamp(87px, 8vw, 104px); }
.section.cream { background: var(--cream); }
.section.dark { background: var(--black); color: #fff; }
.sec-head { max-width: none; margin-bottom: 44px; }
.sec-head .t-label { color: var(--blue); }
.section.dark .sec-head .t-label { color: var(--yellow); }

/* passos "como funciona" */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.step { position: relative; background: var(--white); border: var(--bw-bold) solid var(--ink-900); box-shadow: var(--shadow-pop); padding: 26px 22px 24px; }
.step .n { font-family: var(--font-display); font-variation-settings: 'wght' 900; font-weight: 900; font-size: 64px; line-height: 1; color: var(--cream-deep); }
.step h3 { font-family: var(--font-display); font-variation-settings: 'wdth' 104, 'wght' 750; font-weight: 700; text-transform: uppercase; font-size: 22px; letter-spacing: -.01em; margin: 6px 0 8px; }
.step p { margin: 0; font-size: 15px; color: var(--ink-700); }

/* como funciona — vídeo */
.video-frame { max-width: 920px; margin-inline: auto; border: var(--bw-bold) solid var(--ink-900); box-shadow: var(--shadow-pop-lg); background: #000; line-height: 0; }
.video-ratio { position: relative; padding-top: 56.25%; }
.video-ratio iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.video-cta { text-align: center; margin-top: clamp(24px, 3vw, 36px); }

/* modos */
.modes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.mode-card { background: var(--white); border: var(--bw-bold) solid var(--ink-900); box-shadow: var(--shadow-pop); }
.mode-card .top { padding: 16px 20px; border-bottom: var(--bw-bold) solid var(--ink-900); display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.mode-card .top .name { font-family: var(--font-display); font-variation-settings: 'wdth' 108, 'wght' 800; font-weight: 800; text-transform: uppercase; font-size: 24px; letter-spacing: -.01em; }
.mode-card.seguro .top { background: var(--green); }
.mode-card.padrao .top { background: var(--blue); color: #fff; }
.mode-card.ultra  .top { background: var(--red); color: #fff; }
.mode-card .body { padding: 20px; }
.mode-card .body p { margin: 0 0 14px; font-size: 15px; color: var(--ink-700); }
.mode-card .body .speed { font-family: var(--font-mono); font-size: 13px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-900); display: flex; align-items: center; gap: 8px; }
.mode-card .chev { color: var(--blue); font-weight: 700; }

/* requisitos / o que você precisa */
.sec-head .sec-sub { max-width: 56ch; font-size: clamp(15px, 1.6vw, 18px); line-height: 1.5; color: var(--ink-700); margin: 14px 0 0; }
.reqs { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
.req-wide { grid-column: 1 / -1; }
.req .flow { margin-top: 18px; padding: 0; border: 0; box-shadow: none; background: transparent; }
.notes { margin-top: 24px; background: var(--white); border: var(--bw-bold) solid var(--ink-900); box-shadow: var(--shadow-pop-sm); padding: 20px 22px; }
.notes-title { font-family: var(--font-mono); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; color: var(--ink-900); margin: 0 0 13px; }
.notes-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 11px; }
.notes-list li { display: flex; align-items: flex-start; gap: 11px; font-size: 15px; line-height: 1.45; color: var(--ink-700); }
.notes-list .mk { flex: none; width: 20px; height: 20px; margin-top: 1px; }
.c-ok { color: #119E4B; }
.c-no { color: var(--red); }
.req { background: var(--white); border: var(--bw-bold) solid var(--ink-900); box-shadow: var(--shadow-pop); padding: 26px 22px 24px; }
.req .ico { width: 58px; height: 58px; margin-bottom: 18px; border: var(--bw-bold) solid var(--ink-900); border-radius: var(--radius-sm); background: var(--cream); display: flex; align-items: center; justify-content: center; }
.req .ico svg { width: 38px; height: 38px; }
.req h3 { font-family: var(--font-display); font-variation-settings: 'wdth' 104, 'wght' 750; font-weight: 700; text-transform: uppercase; font-size: 20px; letter-spacing: -.01em; line-height: 1.05; margin: 0 0 8px; }
.req p { margin: 0; font-size: 15px; color: var(--ink-700); }
.req p b { color: var(--ink-900); }
.req p .no { display: inline-block; vertical-align: -2px; }

/* do computador para a TV (fluxo) */
.flow { display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: clamp(12px, 3vw, 32px); background: var(--white); border: var(--bw-bold) solid var(--ink-900); box-shadow: var(--shadow-pop); padding: clamp(28px, 5vw, 48px) clamp(18px, 4vw, 40px); }
.flow-node { display: flex; flex-direction: column; align-items: center; gap: 14px; text-align: center; width: 150px; }
.flow-tv { display: flex; align-items: center; justify-content: center; }
.flow-tv svg { width: 100px; height: 100px; }
.flow-cap { font-family: var(--font-mono); font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: .1em; color: var(--ink-700); line-height: 1.3; }
.flow-op { font-family: var(--font-display); font-variation-settings: 'wght' 900; font-weight: 900; font-size: 40px; line-height: 1; flex: none; color: var(--blue); }
.flow-op.arrow { color: var(--ink-900); }
/* notebook com o ícone na tela */
.laptop { width: 124px; }
.laptop-screen { background: var(--blue); border: var(--bw-bold) solid var(--ink-900); border-radius: 6px 6px 0 0; aspect-ratio: 16 / 10; display: grid; place-items: center; padding: 12px; }
.laptop-screen img { width: 54%; height: auto; object-fit: contain; }
.laptop-base { display: block; width: 150px; margin-left: -13px; height: 9px; background: var(--white); border: var(--bw-bold) solid var(--ink-900); border-radius: 0 0 9px 9px; }
/* meios de conexão (coluna do meio) */
.flow-methods { display: flex; flex-direction: column; gap: 8px; }
.method { display: flex; align-items: center; gap: 13px; }
.method-ico { width: 56px; height: 56px; flex: none; border: var(--bw-bold) solid var(--ink-900); border-radius: var(--radius-sm); background: var(--cream); display: grid; place-items: center; }
.method-ico svg { width: 34px; height: auto; }
.method-cap { display: flex; flex-direction: column; font-family: var(--font-mono); font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; line-height: 1.2; color: var(--ink-900); }
.method-cap small { font-size: 11px; font-weight: 600; color: var(--ink-500); letter-spacing: .06em; margin-top: 2px; }
.method-or { font-family: var(--font-mono); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .16em; color: var(--ink-300); padding-left: 24px; }

/* preço */
.price-wrap { display: flex; justify-content: center; }
.price { position: relative; background: var(--cream); color: var(--ink-900); border: var(--bw-bold) solid var(--ink-900); box-shadow: var(--shadow-pop-lg); padding: 38px 40px; max-width: 460px; width: 100%; text-align: center; }
.price .amt { font-family: var(--font-display); font-variation-settings: 'wght' 900; font-weight: 900; font-size: clamp(56px, 9vw, 88px); line-height: 1; margin: 14px 0; }
.price .amt small { font-family: var(--font-mono); font-size: 16px; font-weight: 500; letter-spacing: .08em; }
.price ul { list-style: none; padding: 0; margin: 20px 0 26px; text-align: left; display: inline-block; }
.price li { display: flex; gap: 10px; align-items: flex-start; margin-bottom: 10px; font-size: 15px; }
.price li::before { content: '★'; color: var(--blue); flex: none; }
.price .badge { position: absolute; top: -16px; left: 50%; transform: translateX(-50%) rotate(-3deg); }
.price-cta { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.price-cta .btn { width: 100%; padding-inline: 20px; white-space: nowrap; }

/* planos (3 cards) */
.plans { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; align-items: stretch; margin-top: 30px; }
.plan { position: relative; display: flex; flex-direction: column; text-align: center;
  background: var(--cream); color: var(--ink-900); border: var(--bw-bold) solid var(--ink-900);
  box-shadow: var(--shadow-pop-lg); padding: 32px 26px; }
.plan .plan-name { font-family: var(--font-display); font-variation-settings: 'wght' 800; font-weight: 800;
  font-size: 22px; line-height: 1.05; margin: 8px 0 0; }
.plan .amt { font-family: var(--font-display); font-variation-settings: 'wght' 900; font-weight: 900;
  font-size: clamp(40px, 5vw, 56px); line-height: 1; margin: 14px 0 8px; }
.plan .amt small { font-family: var(--font-mono); font-size: 15px; font-weight: 500; letter-spacing: .08em; }
.plan .amt .was { display: block; font-family: var(--font-mono); font-size: 16px; font-weight: 600;
  letter-spacing: .04em; color: var(--ink-500); text-decoration: line-through; margin-bottom: 2px; }
.plan .plan-sub { font-size: 14px; line-height: 1.45; color: var(--ink-700); margin: 0 0 16px; }
.plan ul { list-style: none; padding: 0; margin: 2px 0 22px; text-align: left; }
.plan li { display: flex; gap: 10px; align-items: flex-start; margin-bottom: 10px; font-size: 14px; line-height: 1.4; }
.plan li::before { content: '★'; color: var(--blue); flex: none; }
.plan .btn { width: 100%; margin-top: auto; }
.plan .badge { position: absolute; top: -16px; left: 50%; transform: translateX(-50%) rotate(-3deg); }
.plan.feat { background: var(--white); border-color: var(--blue);
  box-shadow: 0 0 0 4px rgba(26,44,240,.18), var(--shadow-pop-lg); transform: translateY(-8px); }

/* contador da promo (card Copa) */
.promo-timer { background: var(--ink-900); color: #fff; padding: 12px 14px; margin: 0 0 18px; }
.promo-timer .pt-label { display: block; font-family: var(--font-mono); font-size: 10px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .12em; color: var(--ink-300); }
.promo-timer .pt-clock { display: block; font-family: var(--font-mono); font-size: 30px; font-weight: 700;
  letter-spacing: .04em; color: var(--yellow); margin: 4px 0; font-variant-numeric: tabular-nums; }
.promo-timer .pt-foot { display: block; font-family: var(--font-mono); font-size: 10px; line-height: 1.4;
  color: rgba(255,255,255,.6); }
.plans-foot { text-align: center; margin: 32px 0 0; }
.plans-foot a { font-family: var(--font-mono); font-size: 13px; font-weight: 600; letter-spacing: .04em; color: var(--yellow); }

/* ---------- FOOTER ---------- */
.footer { background: var(--black); color: rgba(255,255,255,.7); padding-block: 40px; border-top: var(--bw-bold) solid var(--blue); }
.footer .wrap { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 18px; }
.footer .footer-logo { height: 56px; width: auto; }
.footer a { color: rgba(255,255,255,.7); font-family: var(--font-mono); font-size: 12px; text-transform: uppercase; letter-spacing: .1em; }
.footer a:hover { color: var(--yellow); }
.footer .links { display: flex; gap: 22px; flex-wrap: wrap; }

/* ---------- responsivo ---------- */
@media (max-width: 960px) {
  .hero .wrap { grid-template-columns: 1fr; grid-template-rows: auto; grid-template-areas: none; min-height: 0; align-items: start; padding-block: clamp(32px, 6vw, 56px); }
  /* desempilha as grid-areas do desktop: no mobile flui na ordem do HTML */
  .hero-copy, .hero-demo, .hero .lead-tl, .hero .cta { grid-area: auto; }
  .hero-copy { align-self: auto; }
  .hero h1 { max-width: 18ch; }
  .hero-demo { width: min(90vw, 440px); margin-inline: auto; }
  .demo-grid { height: auto; grid-template-rows: none; gap: 10px; border: 0; box-shadow: none; background: transparent; overflow: visible; }
  .feed { border: var(--bw-bold) solid var(--ink-900); box-shadow: var(--shadow-pop); }
  .feed-screen { flex: none; aspect-ratio: 16 / 9; min-height: auto; }
}
@media (max-width: 820px) {
  .steps, .modes, .reqs { grid-template-columns: 1fr; }
  .nav-links { display: none; }
  .price-cta { grid-template-columns: 1fr; }
  .plans { grid-template-columns: 1fr; max-width: 440px; margin-inline: auto; }
  .plan.feat { transform: none; }
}
@media (max-width: 560px) {
  /* hero: ritmo e respiro no mobile */
  .hero .wrap { padding-block: 36px 32px; gap: 26px; }
  .hero .eyebrow { margin-bottom: 18px; gap: 9px; flex-wrap: wrap; }
  .hero h1 { font-size: clamp(34px, 9vw, 50px); max-width: 14ch; }
  .hero-copy { margin-bottom: 20px; }   /* respiro abaixo do titulo, antes dos videos */
  .hero .lead-tl { margin-top: -20px; }  /* timeline puxada pra perto dos videos */
  /* gap entre os cards (figure ja esta com margin:0) */
  .demo-grid { gap: 12px; }

  /* CTA: botões cheios e empilhados (alvo de toque) */
  .hero .cta { flex-direction: column; align-items: stretch; gap: 12px; margin-top: 26px; }
  .hero .cta .btn { width: 100%; }
  .btn.lg { padding: 16px 22px; font-size: 16px; }

  /* timeline: caps menores e mais espaço pro cluster */
  .tl { height: 138px; }
  .tl-cap { font-size: 9px; letter-spacing: 0; }
  .tl-brace-cap { font-size: 10px; padding: 2px 7px; }
  .is-tv .tl-cap { transform: translateX(-62%); }
  .is-fav .tl-cap.strong { font-size: 10.5px; transform: translateX(-34%); }

  /* enfeites: menos poluição na telinha */
  .hero .spark.s1 { width: 34px; top: 8%; right: 5%; }
  .hero .spark.s2 { display: none; }
}
@media (max-width: 760px) {
  .flow { flex-direction: column; }
  .flow-op.arrow { transform: rotate(90deg); }
}
