@font-face {
  font-family: "TikTok Sans";
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../fonts/tiktoksans-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

body {
  font-family: "TikTok Sans", Inter, system-ui, -apple-system, "Segoe UI", Roboto, Arial;
  margin: 0;
  display: flex;
  background-color: #f5f5f5;
  justify-content: center;
  user-select: none;
}
html {
  overflow-x: hidden;
  overscroll-behavior-y: none;
}
* {
  -webkit-touch-callout: none;
}

a[href^="tel"] {
  color: inherit !important;
  text-decoration: none !important;
  pointer-events: none; /* impede o click */
}

/* Remove estilização de link automático em números de telefone */
.telefone,
.telefone a {
  color: #000 !important;
  text-decoration: none !important;
  pointer-events: none;
}

/* Desabilita detecção automática de telefone em Safari/iOS */
a[x-apple-data-detectors] {
  color: inherit !important;
  text-decoration: none !important;
}

/* === regras SPA: controlar visibilidade das screens === */
.screen {
  display: none;
}
.screen.is-active {
  display: block;
}

/* Quando estiver escondida, marque aria-hidden para leitores */
.screen[aria-hidden="true"] {
  display: none;
}

button {
  border: 0;
  box-shadow: none; /* Remove qualquer sombra */
}

/* Remove o contorno azul/preto que aparece ao clicar */
button:focus {
  outline: none;
}
/* .screen {
  border-bottom: 4px solid #ddd;
  padding: 40px 20px;
  min-height: 100vh;
} */
.title {
  text-align: center;
  color: #000;
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  height: 51px;
  display: flex;
  align-items: center;
  justify-content: center;
}
#screens {
  width: 100%;
}
#one {
  background-color: #f5f5f5;
  padding-bottom: 160px; /* Espaço para o sticky popup não cobrir o conteúdo */
  padding-left: 12px;
  padding-right: 12px;
  box-sizing: border-box;
}
/* ===========================
   Card do saldo (container)
   =========================== */
.saldo {
  padding: 20px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.95);
  box-shadow: 0 1px 18.4px 0 rgba(0, 0, 0, 0.03);
  width: 100%;
  max-width: none;
  margin: 0 auto;
  box-sizing: border-box;
  /* Removido height fixo: agora adapta à altura do conteúdo */
}

/* Flex wrapper que organiza esquerda (info) e direita (ação) */
.container-saldo {
  display: flex;
  align-items: flex-end; /* centraliza verticalmente */
  justify-content: space-between; /* empurra o botão para a direita */
  gap: 16px;
}

/* Lado esquerdo: coluna com label e valor */
.saldo-info {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0; /* evita overflow do texto em flex */
}

/* linha com "Seu saldo" e ícone */
.saldo-label {
  display: flex;
  align-items: center;
  gap: 4px;
  color: #444;
  font-size: 14px;
  font-weight: 500;
}

/* ícone pequeno ao lado do label */
.p-saldo {
}

/* valor principal: melhor controle tipográfico */
.saldo-valor {
  display: flex;
  align-items: baseline;
  gap: 6px;
  padding: 0; /* removido padding vertical para centralizar */
}

/* se quiser separar inteiro e decimal (opcional no HTML atual) */
.valor-int {
  font-size: 28px;
  font-weight: 800;
  line-height: 1;
}

.valor-dec {
  font-size: 16px;
  font-weight: 700;
  transform: translateY(-2px);
}

/* Lado direito: botão */
.saldo-action {
  display: flex;
}

.btn-sacar {
  width: 81px;
  height: 27px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  border-radius: 99px;
  background: #fe2b54;
  border: 0;
  position: relative;
}
.btn-text {
  color: #fff;
  font-size: 14px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}
.saldo-text {
  color: #000;
  font-size: 14px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  display: flex;
  align-items: center; /* vertical centralization */
}
.p-bg {
  display: inline-flex;
  width: 13px;
  height: 13px;
  padding: 1.3px;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  border-radius: 185.529px;
  border-bottom: 0.371px solid #faa21c;
  background: #fedc60;
}
.p-txt {
  color: #ffe56a;
  text-shadow: 0 0 1.114px rgba(0, 0, 0, 0.25);
  font-size: 7.851px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  z-index: 10;
}
.valor-currency {
  color: #000;
  font-family: "TikTok Sans", Inter, sans-serif;
  font-size: 22px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
.pay-badge {
  position: absolute;
  top: -8px;
  right: -3px;
}
.pay-badge img {
  width: 31px;
  height: 11px;
  padding: 2px 4px;
  border-radius: 6px 6px 6px 0;
  background: #edf2f1;
}
.parabens {
  display: flex;
  box-sizing: border-box;
}

.parabens-img {
  align-self: flex-start;
  will-change: transform;
  margin-top: -20px;
  max-width: 100%;
}

.parabens-txtum {
  display: block;
  width: 100%;
}
.parabens-txtum,
.parabens-txtdois {
  color: #000;
  font-size: 22px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
.parabens-valor {
  color: #fe2b54;
  font-size: 22px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  display: block;
}
.bloco-dois {
  display: flex;
  flex-direction: column;
  border-radius: 12px;
  background: #fff;
  /* flex-wrap: wrap; */
  box-sizing: border-box;
  width: 100%;
  max-width: none;
  padding: 20px;
  margin: 20px auto;
}

.nobreak {
  white-space: nowrap;
}
.line {
  width: 100%;
  height: 1px; /* controla a espessura */
  border-bottom: 1px dashed rgba(0, 0, 0, 0.1); /* cor bem suave */
  /* margin: 20px 0; */
}
.entre {
  padding-top: 20px;
  display: flex;
  flex-wrap: wrap;
}
.entre-txt {
  width: 244px;
  color: #000;
  font-size: 14px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  flex: 1 1 0;
  min-width: 0;
}
.entre-pts {
  display: block;
  color: #fe2b54;
}

.btn-concluido-text {
  color: #d4d4d4;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}
.btn-concluido {
  width: 89px;
  height: 35px;
  display: inline-flex;
  border-radius: 99px;
  background: #f1f1f3;
  justify-content: center;
  align-items: center;
  pointer-events: none; /* Torna o botão não clicável */
}
.entre-data {
  display: block;
  color: #ce425f;
  font-size: 12px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  margin-top: 6px;
}
.concluiu {
  height: 26px;
  border-radius: 6px;
  background: #f8f9fb;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
}
.concluiu-txt {
  width: 288px;
  color: #848486;
  font-size: 11px;
  font-style: normal;
  font-weight: 500;
  line-height: 14px;
  padding: 6px 12px;
}
/* day tracker */
/* Reset básico para garantir que o padding não estoure o tamanho */
.dia,
.line-dois {
  margin-top: 20px;
  text-align: center;
}
.day-tracker * {
  box-sizing: border-box;
  font-family: "TikTok Sans", Inter, sans-serif; /* Certifique-se de ter a fonte Inter importada */
}

/* Container Principal */
.day-tracker {
  display: flex;
  width: 100%;
  justify-content: space-between;
  align-items: center;
}

/* Coluna do dia individual */
.day-tracker__item {
  width: 45px;
  display: inline-flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 8px;
}

/* Caixa principal do ícone (fundo) */
.day-tracker__box {
  align-self: stretch;
  height: 45px;
  position: relative;
  background: #f8f9fb;
  overflow: hidden;
  border-radius: 8.82px;
  transition: background-color 0.45s ease, border-color 0.45s ease, box-shadow 0.45s ease, transform 0.45s cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* Conteúdo interno (Moeda + Valor) */
.day-tracker__content {
  width: 45px;
  position: absolute;
  left: 0px;
  top: 6px;
  display: inline-flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  gap: 4px;
}

/* Moeda (Círculo Externo) */
.day-tracker__coin {
  width: 16px;
  height: 16px;
  position: relative;
  background: #fedc60;
  overflow: hidden;
  border-radius: 50%; /* 228.34px no original arredondado para 50% */
  border-bottom: 0.46px solid #faa21c;
}
.day-tracker__coin img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

/* Moeda (Círculo Interno) */
.day-tracker__coin-inner {
  width: 12.8px;
  height: 12.8px;
  position: absolute;
  left: 1.6px;
  top: 1.6px;
  background: #ffa31a;
  overflow: hidden;
  border-radius: 50%;
  outline: 0.23px solid #feae0f;
}

/* Efeito de brilho/sombra na moeda */
.day-tracker__coin-effect {
  width: 15.77px;
  height: 15.77px;
  position: absolute;
  left: -1.6px;
  top: -1.6px;
  background: #d9d9d9;
  box-shadow: -0.23px 1.37px 1.14px 0.46px #dc8019;
  border-radius: 9999px;
}

/* Letra "P" dentro da moeda */
.day-tracker__coin-text {
  position: absolute;
  left: 3.43px;
  top: 0.69px;
  color: #ffe56a;
  font-size: 9.66px;
  font-weight: 700;
  text-shadow: 0px 0px 1px rgba(0, 0, 0, 0.25);
}

/* Texto do valor ("50") */
.day-tracker__value {
  align-self: stretch;
  text-align: center;
  color: black;
  font-size: 11px;
  font-weight: 600;
}

/* Overlay (Camada rosa por cima) */
.day-tracker__overlay {
  width: 45px;
  height: 45px; /* Forçado altura para cobrir o box */
  padding: 13px;
  position: absolute;
  left: 0px;
  top: 0px;
  background: rgba(255, 240, 243, 0.9);
  overflow: hidden;
  border-radius: 8.82px;
  display: inline-flex;
  opacity: 1;
  visibility: visible;
  z-index: 2;
  transform: scale(1);
  transition: opacity 0.4s ease, transform 0.4s ease;
  justify-content: flex-start;
  align-items: center;
  gap: 10px;
}

/* Ícone dentro do overlay */
.day-tracker__icon-wrapper {
  width: 19px;
  height: 19px;
  position: relative;
  overflow: hidden;
}

.day-tracker__icon-shape {
  /* width: 18.3px;
  height: 13.32px;
  position: absolute;
  left: 0.35px;
  top: 3.64px;
  background: #fe2b54; */
}

/* Texto inferior ("Dia 01") */
.day-tracker__label {
  align-self: stretch;
  text-align: center;
  color: #a4a4a4;
  font-size: 10px;
  font-weight: 600;
}
.entre-txt-dois {
  padding-right: 18px;
}
.entre-txt-dois .entre-pts {
  display: inline;
}
.assista {
  margin-left: 6px;
  width: 118px;
  height: 19px;
  display: inline-flex;
  border-radius: 99px;
  background: #f1f1f1;
  justify-content: center;
  align-items: center;
  position: relative; /* Cria o contexto de posicionamento */
  overflow: visible; /* Garante que o SVG possa sair para fora da caixa */
}
.assista-tail {
  position: absolute;
  left: 25px; /* A distância que você pediu */
  top: 100%; /* Cola exatamente na borda de baixo */

  /* Dica Pro: Sobe 1 pixel para evitar uma linha branca fina entre o balão e o bico */
  margin-top: -1px;
}
/* .assista::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 25px;
  width: 0;
  height: 0;
  border-left: 4.5px solid transparent;
  border-right: 4.5px solid transparent;
  border-top: 9px solid #f1f1f1;
} */
.assista-txt {
  color: #444;
  font-size: 11px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  text-align: center;
}
/* Container Principal */
.progress-bar {
  position: relative; /* Necessário para a linha absoluta funcionar */
  display: flex;
  justify-content: space-between; /* Espalha os itens igualmente */
  align-items: flex-start;
  width: 100%;
  margin-top: 11px; /* Espaçamento superior */
  padding: 0 10px; /* Um respiro nas laterais */
  box-sizing: border-box;
}

/* A Linha Cinza (Track) */
.progress-bar::before {
  content: "";
  position: absolute;
  top: 12px; /* Ajuste vertical: metade da altura do ícone (ex: 24px / 2) */
  left: 0;
  right: 0;
  height: 5px; /* Espessura da linha */
  background-color: #f1f1f1; /* Cor da linha */
  border-radius: 10px;
  z-index: 0; /* Fica atrás das moedas */
}

/* Cada bloco (Ícone + Texto) */
.progress-step {
  position: relative;
  z-index: 1; /* Garante que fique SOBRE a linha */
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px; /* Distância entre a moeda e o texto */
}

/* Wrapper do Ícone (Moeda) */
.step-icon {
  width: 24px; /* Ajuste o tamanho conforme seu SVG real */
  height: 24px;
  background-color: #fff; /* IMPORTANTE: Esconde a linha atrás da moeda */
  border-radius: 50%; /* Garante que o fundo branco seja redondo */
  display: flex;
  justify-content: center;
  align-items: center;
  /* Opcional: se o SVG for menor que o wrapper, use padding */
}

.step-icon img {
  width: 100%;
  height: 100%;
  display: block;
}

/* Texto dos pontos */
.step-text {
  color: #a4a4a4;
  font-size: 10px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  text-align: center;
}
.hide {
  visibility: hidden;
}
.posicao-direita {
  align-self: flex-end; /* Para flex-direction: column */
  margin-left: auto; /* Para flex-direction: row */
}

/* Opcional: Faz a setinha (tail) ficar na direita também */
.posicao-direita .assista-tail {
  left: auto; /* Desliga o posicionamento esquerdo */
}
.assista {
  display: flex;
}
.taildois {
  position: absolute;
  right: 39px;
  top: 100%; /* Cola exatamente na borda de baixo */

  /* Dica Pro: Sobe 1 pixel para evitar uma linha branca fina entre o balão e o bico */
  margin-top: -1px;
}
.obtem-txt {
  margin-top: 20px;
  margin-left: 9px;
  display: inline-block;
  width: 288px;
  color: #848486;
  font-size: 11px;
  font-style: normal;
  font-weight: 500;
  line-height: 14px;
}
.popup {
  padding: 64px 20px 20px;
  text-align: center;
  width: 320px;
  box-sizing: border-box;
  overflow: visible;
  border-radius: 20px;
  background: linear-gradient(180deg, #fff8f0 0%, #fff 100%);
  position: relative;
  margin: 60px auto 12px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  box-shadow: 0 8px 32px rgba(0,0,0,0.12);
}
.gol {
  color: #000;
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  padding-top: 5px;
  display: block;
}
.gol-img {
  width: 130px;
  height: 130px;
  object-fit: contain;
  position: absolute;
  top: -78px;
  left: 50%;
  transform: translateX(-50%);
  background: transparent;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.22)) drop-shadow(0 2px 6px rgba(255,138,0,.25));
  pointer-events: none;
}
.gol-txt {
  padding-top: 12px;
  width: 270px;
  display: inline-flex;
  color: #403f3a;
  font-size: 14px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  text-align: center;
}
.gol-valor {
  display: inline-flex;
  padding-top: 20px;
  margin-bottom: 10px;
  color: #000;
  font-size: 36px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
.timer-wrapper {
  margin-top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.timer-clock {
  gap: 4px;
  display: flex; /* 1. Transforma em um container flexível */
  align-items: center; /* 2. Alinha todos os filhos (caixas E separadores) verticalmente */
  justify-content: center; /* 3. Alinha horizontalmente no centro */
}
.timer-box {
  display: flex;
  padding: 4px;
  border-radius: 2px;
  background: #f1f1f3;
  justify-content: center;
  align-items: center;
  font-size: 10px;
}
.timer-label {
  color: #403f3a;
  font-size: 10px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  text-align: center;
}

.btn-obrigado {
  width: 270px;
  height: 53px;
  justify-content: center;
  align-items: center;
  border-radius: 99px;
  background: #fe2b54;
  border: 0;
  display: flex;
  margin: 12px auto 0 auto; /* adiciona espaçamento acima e centraliza */
  cursor: pointer;
}

/* Botão dentro do popup deve respeitar o padding-bottom */
.popup > .btn-obrigado {
  margin-bottom: 0;
  margin-top: auto; /* empurra para baixo se necessário */
}
.saldo-dois {
  width: 100%;
  height: 130px;
  overflow: hidden;
  border-radius: 10px;
  /* border-bottom: 1px dashed #303030; */
  flex-shrink: 0;
  background: #000;
  box-sizing: border-box;
}
.saldo-text-dois {
  color: #fff;
  font-size: 17px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}
.valor-currency-dois {
  color: #fff;
  font-size: 30px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
.total-pontos {
  color: #828282;
  font-size: 14px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}
.saldo-valor-dois {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.saldo-info-dois {
  gap: 8px;
}
.saldo-tres {
  display: flex;
  width: 100%;
  overflow: hidden;
  padding: 10px 20px;
  border-radius: 10px;
  background: #000;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  box-sizing: border-box;
}
.total-pontos-dois {
  color: #828282;
  font-family: "TikTok Sans", Inter, sans-serif;
  font-size: 13px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
}

#three {
  background-color: #f5f5f5;
  padding-left: 12px;
  padding-right: 12px;
  padding-bottom: 12px;
  box-sizing: border-box;
}
.saldo-dois {
  --display: flex;
  --min-height: 117px;
  --flex-direction: row;
  --container-widget-width: calc(
    (1 - var(--container-widget-flex-grow)) * 100%
  );
  --container-widget-height: 100%;
  --container-widget-flex-grow: 1;
  --container-widget-align-self: stretch;
  --flex-wrap-mobile: wrap;
  --align-items: center;
  border-style: dashed;
  --border-style: dashed;
  border-width: 0px 0px 1px 0px;
  --border-top-width: 0px;
  --border-right-width: 0px;
  --border-bottom-width: 1px;
  --border-left-width: 0px;
  border-color: #303030;
  --border-color: #303030;
  --border-radius: 12px 12px 12px 12px;
  --padding-top: 0px;
  --padding-bottom: 0px;
  --padding-left: 0px;
  --padding-right: 0px;
}
.saldo-sacar {
  margin-top: 16px;
}
.saldo-sacar-text {
  color: #000;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
.transferencia-txt {
  color: #828282;
  font-size: 13px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
}
.pay-logo-transf {
  width: 40px;
  height: 13.684px;
  padding-left: 4px;
}

.saldo-valor-tres {
  height: 34px;
  gap: 16px;
  display: flex;
  align-items: center;
  gap: 6px; /* espaçamento entre itens */
  /* opcional: evitar quebra */
  /* flex-wrap: nowrap; */
  border-bottom: 1px solid #e2e2e4;
  padding-bottom: 5px;
  margin-bottom: 12px;
}

/* garante que o texto e os ícones internos fiquem em linha e centrados */
.transferencia-txt {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.saldo-info-sacar {
  gap: 16px;
}

.widget-container {
  /* Define uma largura para o container principal */
  margin-top: 21px;
}

.botoes-row {
  display: flex; /* Alinha os botões em linha */
  gap: 8px; /* Espaço entre os botões */
  margin-bottom: 10px; /* Espaço abaixo da linha de botões */
}

.btn-valor {
  flex: 1; /* Faz os botões dividirem o espaço igualmente */

  /* Cor de fundo cinza claro */
  background-color: #f0f2f5;

  /* Borda transparente para evitar que o layout "pule" ao adicionar a borda ativa */
  border: 1.5px solid transparent;

  border-radius: 6px; /* Cantos arredondados */
  padding: 12px 0; /* Espaçamento interno (vertical, horizontal) */
  font-size: 16px;
  font-weight: bold;
  color: #333; /* Cor do texto (escuro) */
  cursor: pointer;
  transition: all 0.2s ease; /* Efeito de transição suave */
}

/* Estilo do botão ativo (selecionado) */
.btn-valor.btn-active {
  background-color: #fff6f7; /* Fundo rosa bem claro */
  border-color: #f84d63; /* Cor da borda rosa/vermelho */
  color: #f84d63; /* Cor do texto rosa/vermelho */
}
.botoes-row > .btn-valor {
  color: #000;
  text-align: center;
  font-family: "TikTok Sans", Inter, sans-serif;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
.botoes-row > .btn-active {
  color: #f82e5a;
}
.display-total {
  display: flex;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
  width: 100%;
  height: 50px;
  background-color: #f0f2f5; /* Mesmo cinza dos botões */
  border-radius: 8px; /* Mesmos cantos arredondados */
  text-align: center;
  font-size: 16px; /* Fonte maior */
  font-weight: 700;
  padding: 10px;
  color: #000; /* Cor do texto */
}
.botoes-row-sacar {
  margin-bottom: 8px;
}
.btn-sacar-dois {
  box-sizing: border-box;
  display: flex;
  width: 100%;
  height: 41px;
  border-radius: 8px;
  background: #fe2b54;
  justify-content: center;
  align-items: center;
  gap: 10px;
}
.obtem-sacar > .obtem-txt {
  color: #747378;
  font-size: 11px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}
.btn-textdois-sacar {
  color: #fff;
  font-size: 14px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}
.obtenha-title {
  gap: 8px;
}
.moedas-txt {
  width: 251px;
  color: #747378;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}

/* Inverte apenas quando houver a flor dentro do bloco de saque */
.saldo-sacar .container-saldo {
  align-items: center; /* centra verticalmente texto e imagem */
}
.flor {
  width: 82px;
  height: 82px;
  flex-shrink: 0;
  aspect-ratio: 1/1;
  margin-right: -20px;
}
.saldo-sacar .flor {
  order: 2; /* manda a imagem para o fim do flex container (direita) */
  align-self: center;
  margin-left: -30px; /* espaço entre texto e imagem */
  flex-shrink: 0; /* evita que a imagem encolha */
}
.saldo-sacar .obtenha-title {
  order: 1; /* garante que o texto venha antes da imagem */
}
.btn-sacar-indisponivel {
  display: flex;
  width: 100%;
  height: 41px;
  padding: 12px 10px;
  border-radius: 8px;
  background: #f1f1f3;
  justify-content: center;
  align-items: center;
  gap: 10px;
  cursor: not-allowed;
  pointer-events: none; /* 🔥 evita clique */
  opacity: 0.6; /* deixa visualmente bloqueado */
}
.btn-indis {
  color: #d4d4d4;
  font-size: 14px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}
.ddd,
.telefone {
  color: #ababab !important;
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
}
.linha-ddd {
  width: 1px;
  height: 18px;
  background: #e4e4e4;
}
.obtem-sacar > .recarga-txt {
  color: #747378;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  text-align: center;
}
.border-none {
  border: 0;
}
.saque-title {
  overflow: hidden;
  background: #fefefe;
  border-bottom: 1px solid #e0e0e0;
}
.saque-popup {
  height: 300px;
  margin: 0 auto;
  box-sizing: border-box;
  background-color: #fefefe;
  /* border-radius: 10px 10px 0 0; */
  border-radius: 10px;
  overflow: hidden;
}
#five .saque-popup,
#six .saque-popup {
  height: auto !important;
  min-height: 300px;
}
#four {
}
#four a {
  text-decoration: none;
}
.pay-solo {
  width: 22px;
  height: 22px;
  object-fit: contain;
  border-radius: 3px;
}
.pay-title {
  align-self: stretch;
  color: #000;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}
.pay-subtitle {
  align-self: stretch;
  color: #747378;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}
.pay-icon {
  display: flex;
  width: 36px;
  height: 28px;
  overflow: hidden;
  border-radius: 5px;
  border: 1px solid #e3e3e3;
  box-sizing: border-box;
  background: #fefeff;
  justify-content: center;
  align-items: center;
}
.pay-item {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  background-color: #fefefe;
  height: 42px;
  padding: 16px;
  cursor: pointer;
  transition: background-color 0.15s ease;
  user-select: none;
}

.pay-item:hover {
  background-color: #f8f8f8;
}

.pay-item:active {
  background-color: #e8e8e8;
}
.pay-details {
  display: flex;
  flex-direction: column;
}
.pay-subtitle {
  margin-top: 8px;
}
.pay-arrow {
  margin-left: auto; /* empurra para a direita */
  align-self: flex-start; /* cola no topo do container flex */
  /* já tem width/height, ajuste se precisar */
  width: 25px;
  height: 25px;
  display: flex;
  justify-content: center;
  align-items: center;
} /* Define uma fonte base e um fundo para melhor visualização */

/* O contêiner principal do nosso formulário */
.form-container {
  box-sizing: border-box;
  padding: 20px;
  background-color: #ffffff;
}

/* Espaçamento entre os grupos de campos */
.form-group {
  margin-bottom: 24px;
}
.form-group:last-child {
  margin-bottom: 0;
}

/* Estilo dos rótulos do formulário */
.field-label {
  font-size: 16px;
  font-weight: 600; /* Um "negrito" suave */
  color: #1c1e21; /* Cor preta/cinza escuro */
  display: block;
}

/* Estilo do campo de input (Nome completo) */
input[type="text"] {
  width: 100%;
  border: none; /* Remove todas as bordas */
  border-bottom: 1px solid #ddd; /* Adiciona apenas a linha inferior */
  font-size: 16px;

  background-color: transparent; /* Fundo transparente */
}

/* Cor do texto do placeholder */
input[type="text"]::placeholder {
  color: #999;
  opacity: 1;
}

/* Remove a borda azul padrão ao focar no input */
input[type="text"]:focus {
  outline: none;
  border-bottom-color: #555; /* Pode mudar a cor da linha ao focar */
}

/* Estilo do 'botão' seletor */
.pay-selector {
  margin-top: 20px;
  padding-bottom: 16px;
  width: 100%;
  border: none;
  border-bottom: 1px solid #ddd;
  font-size: 16px;
  background-color: transparent;

  /* Mágica do layout: alinha o texto e a seta */
  display: flex;
  justify-content: space-between;
  align-items: center;

  cursor: pointer; /* Muda o mouse para 'mãozinha' */
  transition: background-color 0.2s ease;
}

/* Efeito suave ao passar o mouse */
.pay-selector:hover {
  background-color: #f9f9f9;
}

/* Texto 'Escolha o tipo...' */
.pay-selector .placeholder-text {
  color: #999; /* Mesma cor do placeholder */
}

/* A seta '>' */
.pay-selector .arrow {
  color: #999;
  font-weight: bold;
  font-size: 18px;
}
.field-label {
  color: #000;
  font-size: 14px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}
input.nome-completo {
  margin-top: 20px;
  padding-bottom: 16px;
}
input.nome-completo,
.placeholder-text {
  color: #000;
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
}
.arrow-tois {
  margin-left: auto; /* empurra para a direita */
  align-self: flex-start;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 4.857px;
  height: 8.943px;
  flex-shrink: 0;
}
.btn-vincular {
  margin-top: -5px;
}

/* Botão dentro da #five deve ter width 100% */
#five .btn-vincular,
#five .btn-sacar-dois {
  width: 100%;
  max-width: 100%;
} /* O contêiner principal para a lista de seleção */
.selection-container {
  width: 100%;
  max-width: 400px;
  background-color: #ffffff;
  border-radius: 8px;
  overflow: hidden; /* Garante que as bordas fiquem bonitas */
}

/* Cada linha de opção */
.option-row {
  /* Define o "container" para nossa linha falsa */
  position: relative;
}

/* "Desenha" a linha falsa como um elemento ::after */
.option-row::after {
  content: "";
  position: absolute;
  bottom: 0; /* Alinha na parte de baixo */
  height: 1px;
  background-color: #ddd; /* A cor da sua linha */

  /* A MÁGICA: Define o recuo de 20px em cada lado */
  left: 20px;
  right: 20px;
}

/* Esconde a linha falsa do último item da lista */
.option-row:last-child::after {
  /* display: none; */
}
/* O 'label' é o nosso contêiner flexível */
.option-row label {
  display: flex;
  justify-content: space-between; /* Joga o texto para a esquerda e o rádio para a direita */
  align-items: center;
  padding: 20px 20px 0px 20px;
  cursor: pointer;
  transition: background-color 0.2s ease;
  /* border-bottom: 1px solid #ddd; */
}

.option-row label:hover {
  /* background-color: #f9f9f9; */
}

/* O texto (CPF, E-mail, etc.) */
.option-text {
  color: #000;
  font-size: 14px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}

/* 1. ESCONDEMOS O RÁDIO ORIGINAL */
.option-row input[type="radio"] {
  display: none;
}

/* 2. CRIAMOS O NOSSO RÁDIO FALSO (O CÍRCULO) */
.custom-radio {
  display: block;
  width: 20px;
  height: 20px;
  border-radius: 50%; /* Deixa redondo */

  /* Estilo "Não selecionado" (borda cinza, fundo branco) */
  border: 2px solid #e0e0e0;
  background-color: #fff;
  box-sizing: border-box;
  transition: all 0.2s ease-in-out; /* Animação suave */
}

/* 3. A MÁGICA: MUDAMOS O ESTILO DO RÁDIO FALSO QUANDO O ORIGINAL ESTÁ :checked */
.option-row input[type="radio"]:checked + .custom-radio {
  border-color: #fff; /* Borda rosa */
  background-color: #ff2657; /* <--- Mude aqui para a cor rosa */
  box-shadow: 0 0 0 1px #ff2657; /* Brilho externo */
  box-sizing: border-box;
  border-width: 2.5px;
}
.option-row label {
  padding-bottom: 13px;
}
/* =========================================
   Estilos para a nova tela de loading (#seven)
   ========================================= */

/* Preloader fake (sem animação de spin) */
#preloader-fake {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: white;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
  visibility: visible; /* Inicia visível */
  opacity: 1; /* Inicia com opacidade total */
  transition: opacity 0.5s ease, visibility 0.5s ease; /* Animação para ocultar */
}

/* Estilo da página de carregamento após o preloader fake */
#loading-page {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #ffffff;
  display: flex;
  flex-direction: column;
  justify-content: flex-end; /* Alinha os itens ao fundo */
  align-items: flex-start; /* Alinha os itens à esquerda */
  padding-left: 20px;
  padding-right: 20px;
  z-index: 9998;
  visibility: hidden; /* Inicialmente oculto */
  opacity: 1; /* Opacidade total no início */
  transition: opacity 1s ease, visibility 1s ease; /* Animação de fade out */
  box-sizing: border-box;
}

/* Barra de progresso */
.progress-bar-loading {
  width: 100%;
  height: 8px;
  background-color: #d8d8d8;
  border-radius: 4px;
  margin-top: 48px;
  margin-bottom: 100px;
  position: relative;
  overflow: hidden;
  min-width: 0;
  flex-shrink: 1;
}

.progress-bar-fill {
  height: 100%;
  width: 0%; /* Começa com 0% */
  background-color: #fe2b54;
  transition: width 2s ease; /* Animação de transição suave para a largura da barra */
}

/* Status text */
.status-text {
  font-family: "TikTok Sans", Inter, sans-serif;
  font-weight: 900; /* Fonte mais grossa */
  font-size: 28px;
  color: black;
  margin-top: 48px;
  width: 100%;
  text-align: left; /* Alinhado à esquerda */
  transform: translateY(20px); /* Começa ligeiramente abaixo */
  opacity: 0; /* Começa invisível */
  transition: transform 0.5s ease, opacity 0.5s ease; /* Animação de deslizar para cima */
  min-width: 0;
  flex-shrink: 1;
}

/* Quando #seven estiver ativo, permite overflow hidden no body */
body.loading-active {
  overflow: hidden;
}

/* Garante que #seven ocupe toda a tela */
#seven {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #ffffff;
  z-index: 10000;
}

/* =========================================
   Estilos para a página de confirmação (#nine)
   ========================================= */
#nine {
  background-color: #ffffff;
  padding: 0;
  overflow-y: auto;
  height: 100dvh; /* Use dynamic viewport height */
  min-height: 100dvh;
  box-sizing: border-box;
  position: relative;
}

/* Garante que #nine comece no topo quando exibida */
#nine.is-active {
  scroll-behavior: auto;
}

.confirmation-container {
  padding-top: 16px;
  padding-left: 16px;
  padding-right: 16px;
  max-width: 480px;
  margin: 0 auto;
  box-sizing: border-box;
  padding-bottom: 0;
  width: 100%;
  overflow-x: hidden; /* Previne overflow horizontal */
}

.confirmation-section {
  box-sizing: border-box;
  width: 100%;
}

.confirmation-header {
  padding: 16px 16px 12px;
  text-align: center;
  border-bottom: 1px solid #e5e5e5;
}

.confirmation-logo {
  height: 28px;
  display: inline-block;
  margin-bottom: 12px;
}

.confirmation-logo img {
  height: 100%;
  width: auto;
}

.confirmation-section {
  background: #ffffff;
  border: 1px solid #e5e5e5;
  border-radius: 10px;
  padding: 20px;
  margin-bottom: 16px;
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  overflow: hidden; /* Previne que filhos ultrapassem */
}

.confirmation-balance {
  background: linear-gradient(135deg, #000000, #1a1a1a);
  color: white;
  border: none;
}

.confirmation-section-title {
  font-size: 13px;
  font-weight: 500;
  color: #666666;
  margin-bottom: 12px;
  letter-spacing: 0.02em;
}

.confirmation-balance-title {
  color: rgba(255, 255, 255, 0.9);
  font-size: 12px;
  font-weight: 500;
  margin-bottom: 6px;
}

.confirmation-balance-amount {
  font-size: 28px;
  font-weight: 600;
  margin-bottom: 6px;
  letter-spacing: -0.02em;
}

.confirmation-balance-subtitle {
  font-size: 12px;
  opacity: 0.9;
  font-weight: 400;
}

.confirmation-fee-amount {
  font-size: 22px;
  font-weight: 600;
  color: #ea445a;
  margin-bottom: 12px;
  letter-spacing: -0.01em;
}

.confirmation-fee-description {
  font-size: 13px;
  color: #666666;
  line-height: 1.4;
}

.confirmation-receipt-grid {
  display: grid;
  gap: 12px;
}

.confirmation-receipt-item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding-bottom: 12px;
  border-bottom: 1px solid #e5e5e5;
}

.confirmation-receipt-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.confirmation-receipt-label {
  font-size: 12px;
  color: #666666;
  font-weight: 400;
}

.confirmation-receipt-value {
  font-size: 12px;
  font-weight: 500;
  color: #1a1a1a;
  text-align: right;
}

.confirmation-pay-key {
  background: #f8f8f8;
  border: 1px solid #e5e5e5;
  border-radius: 5px;
  padding: 12px;
  font-family: "Monaco", "Menlo", monospace;
  font-size: 11px;
  text-align: center;
  color: #1a1a1a;
  margin-top: 6px;
  word-break: break-all;
}

.confirmation-divider {
  height: 1px;
  background: #e5e5e5;
  margin: 16px 0;
}

.confirmation-requirements-grid {
  display: grid;
  gap: 16px;
}

.confirmation-requirement-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.confirmation-requirement-icon {
  background: rgba(234, 68, 90, 0.1);
  color: #ea445a;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 13px;
}

.confirmation-requirement-icon.confirmation-reembolso {
  background: rgba(16, 185, 129, 0.1);
  color: #10b981;
}

.confirmation-requirement-content {
  flex: 1;
}

.confirmation-requirement-title {
  font-size: 13px;
  font-weight: 500;
  color: #1a1a1a;
  margin-bottom: 3px;
}

.confirmation-requirement-title.confirmation-reembolso {
  color: #10b981;
}

.confirmation-requirement-description {
  font-size: 12px;
  color: #666666;
  line-height: 1.4;
}

.confirmation-cta-button {
  background: #ea445a;
  color: white;
  border: none;
  border-radius: 7px;
  padding: 16px;
  font-size: 15px;
  font-weight: 500;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  cursor: pointer;
  transition: opacity 0.2s;
  margin-bottom: 12px;
  letter-spacing: 0.01em;
  text-decoration: none;
  display: block;
  text-align: center;
  word-wrap: break-word;
  overflow-wrap: break-word;
  outline: none;
  box-shadow: none;
}

.confirmation-cta-button:focus,
.confirmation-cta-button:active,
.confirmation-cta-button:visited,
.confirmation-cta-button:hover {
  outline: none;
  border: none;
  text-decoration: none;
  color: white;
}

.confirmation-cta-button:hover {
  opacity: 0.95;
}

.confirmation-timer {
  font-size: 11px;
  color: #10b981;
  font-weight: 500;
  text-align: center;
  margin-top: 12px;
}

.confirmation-success-message {
  background: rgba(16, 185, 129, 0.1);
  border: 1px solid rgba(16, 185, 129, 0.2);
  border-radius: 6px;
  padding: 12px;
  text-align: center;
  color: #10b981;
  font-weight: 500;
  font-size: 13px;
  margin-top: 12px;
  display: none;
}

.confirmation-reembolso-badge {
  display: inline-block;
  background: rgba(16, 185, 129, 0.1);
  color: #10b981;
  padding: 4px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 500;
  margin-left: 6px;
}

.confirmation-security-grid {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 50px;
  margin: 20px 0;
}

.confirmation-security-item {
  text-align: center;
}

.confirmation-security-icon {
  font-size: 14px;
  color: #ea445a;
  margin-bottom: 6px;
}

.confirmation-security-label {
  font-size: 10px;
  color: #999999;
  font-weight: 400;
}

.confirmation-footer {
  text-align: center;
  padding: 16px 0;
  border-top: 1px solid #e5e5e5;
}

.confirmation-footer-text {
  font-size: 11px;
  color: #999999;
  margin-bottom: 6px;
}

.confirmation-footer-link {
  color: #ea445a;
  text-decoration: none;
  font-weight: 500;
  font-size: 11px;
}
.expira-saldo {
  width: 100vw;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  box-sizing: border-box;
}
.timer-wrapper {
  font-family: "TikTok Sans", Inter, system-ui, -apple-system, "Segoe UI", Roboto, Arial;
  /* Cor de fundo cinza, como na imagem */
  background-color: #e6e6e6;
  border-radius: 4px;
  height: 36px;
}

#countdown-text {
  color: #000;
  font-size: 10px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  text-transform: uppercase;
}

#timer {
  color: #000;
  font-size: 10px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  text-transform: uppercase;
}
.saldo-dois {
  margin-top: 20px;
}
.sticky-popup {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0; /* Garante que o margin: 0 auto funcione para centralizar */
  margin: 0 auto; /* Centraliza no desktop */
  width: 100%;
  max-width: 350px; /* Mesma largura do container principal (.saldo) */
  z-index: 99;
  transform: translateY(100%); /* Escondido por padrão */
  transition: transform 0.3s ease-in-out;
  display: block;
  pointer-events: none; /* Evita bloquear cliques quando escondido (se transform falhar) */
}

.sticky-popup.is-visible {
  transform: translateY(0);
  pointer-events: auto;
}

.saldo-popup,
.expira-em-popup {
  background-color: white;
  margin: 0 auto; /* Centraliza o conteúdo se tiver max-width */
  max-width: 100%; /* Garante que ocupe a largura */
}
/* Apenas o timer do popup-um (sticky bottom) usa #F4F4F4 */
#popup-um .expira-em-popup {
  background-color: #F4F4F4;
  height: auto !important;
  padding-top: 14px !important;
  padding-bottom: 14px !important;
}

/* Timer boxes (00 : 16 : 34) — fundo branco em cada par de dígitos */
#popup-um .timer-box {
  background: #fff !important;
  padding: 5px 8px !important;
  border-radius: 6px !important;
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 12px;
  font-weight: 700;
  color: #161823;
  letter-spacing: 0;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1, "lnum" 1;
  min-width: 24px;
  justify-content: center;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}
#popup-um .timer-separator {
  color: #86878B;
  font-weight: 700;
  font-size: 12px;
  margin: 0 2px;
}
#popup-um .timer-label {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  color: #86878B;
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: -0.05px;
}

.saldo-popup {
  border-radius: 0;
  padding-bottom: 20px; /* Espaço extra para segurança em mobile */
}

.expira-em-popup {
  border-radius: 8px 8px 0 0;
  width: fit-content; /* O timer só ocupa o necessário */
  padding: 0 15px; /* Padding lateral */
  margin: 0 auto; /* Centraliza horizontalmente (para o popup #two) */
}

/* Ajuste específico para o sticky popup (#popup-um) */
#popup-um .expira-em-popup {
  width: 100%; /* Ocupa 100% da largura */
  display: flex;
  justify-content: center; /* Centraliza o conteúdo interno */
  margin: 0; /* Remove margem auto pois width é 100% */
  box-sizing: border-box;
}
.line-expira {
}
.expira-em-popup {
  --display: flex;
  --min-height: 117px;
  --flex-direction: row;
  --container-widget-width: calc(
    (1 - var(--container-widget-flex-grow)) * 100%
  );
  --container-widget-height: 100%;
  --container-widget-flex-grow: 1;
  --container-widget-align-self: stretch;
  --flex-wrap-mobile: wrap;
  --align-items: center;
  border-style: dashed;
  --border-style: dashed;
  border-width: 0px 0px 1px 0px;
  --border-top-width: 0px;
  --border-right-width: 0px;
  --border-bottom-width: 1px;
  --border-left-width: 0px;
  border-color: #f5f5f5;
  --border-color: #f5f5f5;
  --border-radius: 12px 12px 12px 12px;
  --padding-top: 0px;
  --padding-bottom: 0px;
  --padding-left: 0px;
  --padding-right: 0px;
}
.timer-separator {
  width: 3px;
  height: 7px;
  color: #000;
  font-size: 10px;
  font-style: normal;
  font-weight: 500;
  line-height: 53%;
  text-align: center;
}
.btn-txt-obrigado {
  color: #fff;
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}
.popup > .timer-wrapper {
  background: none;
}

/* === modal popup (section id="two") — entrada/saída cinematográfica === */
.screen.is-modal {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  background: rgba(0, 0, 0, 0);
  -webkit-backdrop-filter: blur(0);
  backdrop-filter: blur(0);
  padding: 1.5rem;
  box-sizing: border-box;
  transition: background .32s ease-out, backdrop-filter .32s ease-out, -webkit-backdrop-filter .32s ease-out;
}
.screen.is-modal.is-active {
  display: flex;
  background: rgba(0, 0, 0, 0.55);
  -webkit-backdrop-filter: blur(5px);
  backdrop-filter: blur(5px);
}
.screen.is-modal .modal-inner {
  max-width: 720px;
  width: 100%;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.25);
  padding: 1.5rem;
  box-sizing: border-box;
  position: relative;
}

/* Entrada do popup (escala + slide-up + fade) */
.screen.is-modal .modal-inner > .popup {
  opacity: 0;
  transform: scale(0.82) translateY(22px);
  transition: opacity .42s cubic-bezier(.22,1,.36,1),
              transform .58s cubic-bezier(.22,1.18,.36,1);
  /* Promove pra camada própria GPU — anima sem disparar reflow no main thread */
  will-change: transform, opacity;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}
.screen.is-modal.is-active .modal-inner > .popup {
  opacity: 1;
  transform: scale(1) translateY(0);
}

/* Stagger interno: ícone gol bounce, textos fade up */
.screen.is-modal.is-active .gol-img {
  animation: golImgPop .72s cubic-bezier(.34,1.7,.5,1) .12s both;
}
.screen.is-modal.is-active .gol {
  animation: golFadeUp .55s cubic-bezier(.22,1,.36,1) .22s both;
}
.screen.is-modal.is-active .gol-txt {
  animation: golFadeUp .55s cubic-bezier(.22,1,.36,1) .32s both;
}
.screen.is-modal.is-active .gol-valor {
  animation: golFadeUp .55s cubic-bezier(.22,1,.36,1) .42s both;
}
.screen.is-modal.is-active .expira-em-popup {
  animation: golFadeUp .55s cubic-bezier(.22,1,.36,1) .52s both;
}
.screen.is-modal.is-active .btn-obrigado {
  animation: golFadeUp .55s cubic-bezier(.22,1,.36,1) .62s both,
             btnObrigadoIdlePulse 2.6s ease-in-out infinite 2.2s;
}
@keyframes golImgPop {
  0% { opacity: 0; transform: translateX(-50%) scale(.3) rotate(-25deg); }
  60% { opacity: 1; transform: translateX(-50%) scale(1.18) rotate(8deg); }
  100% { opacity: 1; transform: translateX(-50%) scale(1) rotate(0); }
}
@keyframes golFadeUp {
  from { opacity: 0; transform: translateY(14px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes btnObrigadoIdlePulse {
  0%, 100% { box-shadow: 0 6px 18px rgba(254,43,84,.35); transform: translateY(0); }
  50% { box-shadow: 0 10px 28px rgba(254,43,84,.55); transform: translateY(-2px); }
}

/* Saída SIMPLES — fade + slide down rápido (300ms). Sem blur transition (=GPU-livre) */
.screen.is-modal.is-leaving {
  background: rgba(0, 0, 0, 0);
  transition: background .3s ease-out;
}
.screen.is-modal.is-leaving .modal-inner > .popup {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity .3s ease-out, transform .3s ease-out;
}
.screen.is-modal.is-leaving .gol-img,
.screen.is-modal.is-leaving .gol,
.screen.is-modal.is-leaving .gol-txt,
.screen.is-modal.is-leaving .gol-valor,
.screen.is-modal.is-leaving .expira-em-popup,
.screen.is-modal.is-leaving .btn-obrigado {
  animation: none !important;
}

/* Botão Obrigado: click feedback + shimmer */
.btn-obrigado {
  transition: filter .15s, transform .15s ease, box-shadow .25s ease;
  position: relative;
  overflow: hidden;
}
.btn-obrigado:active {
  filter: brightness(.94);
  transform: scale(.97);
}
.btn-obrigado.clicked {
  animation: btnObrigadoBurst .58s cubic-bezier(.32,1.6,.5,1) !important;
}
@keyframes btnObrigadoBurst {
  0% { transform: scale(1); }
  28% { transform: scale(.93); }
  58% { transform: scale(1.07); }
  100% { transform: scale(1); }
}
.btn-obrigado::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  left: -42%;
  width: 38%;
  background: linear-gradient(110deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.42) 50%, rgba(255,255,255,0) 100%);
  transform: skewX(-22deg);
  pointer-events: none;
}
.screen.is-modal.is-active .btn-obrigado::after {
  animation: btnObrigadoShimmer 2.6s ease-in-out infinite 1.4s;
}
@keyframes btnObrigadoShimmer {
  0% { left: -42%; }
  55% { left: 130%; }
  100% { left: 130%; }
}

/* Evita scroll do body quando modal aberto */
body.modal-open {
  overflow: hidden;
}

/* Pequeno ajuste para o clique "fora" dentro do modal: garantir que o conteúdo interno não propague clique */
.screen.is-modal .modal-inner * {
  pointer-events: auto;
}
#two > .modal-inner {
  background: none;
  box-shadow: none;
  margin: 0;
  padding: 0;
}
button:hover {
  cursor: pointer;
}

/* sera */
/* sera */
.modal-screen {
  position: fixed;
  inset: 0; /* ocupa a tela inteira */
  background: rgba(0, 0, 0, 0.45);
  display: none; /* começa escondida */
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

.modal-screen.is-active {
  display: flex; /* aparece como popup */
}
/* === modal popup #four — colado na parte inferior, full width === */
#four.is-modal,
#four.is-modal.is-active {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  justify-content: center;
  align-items: flex-end; /* Alinha na parte inferior */
  background: rgba(0, 0, 0, 0.45);
  padding: 0; /* Remove padding para full width */
  box-sizing: border-box;
}
/* garante que o conteúdo do modal continue acima do overlay */
#four .modal-inner {
  position: relative;
  z-index: 10000;
  width: 100%; /* Full width */
  max-width: 100%; /* Remove limite de largura */
  border-radius: 12px 12px 0 0; /* Sem border-radius bottom */
  margin: 0;
  padding: 1.5rem;
  background: #fff;
  box-sizing: border-box;
}
.bold {
  font-weight: bold;
}

/* transforma sections com class .modal em overlay */
.modal {
  position: fixed;
  inset: 0; /* top:0; right:0; bottom:0; left:0 */
  display: none; /* escondido por padrão */
  justify-content: center;
  align-items: center;
  z-index: 9999;
  pointer-events: none; /* evita interação quando fechado */
}

/* quando o modal for ativado pelo JS */
.modal.is-modal.is-active,
.modal.is-active.is-modal {
  display: flex;
  pointer-events: auto;
  background: rgba(0, 0, 0, 0.55); /* escurece o fundo */
  /* backdrop-filter blur removido — caro em mobile (10-15fps drop) */
  /* webkit-backdrop-filter removido pra performance */
}

/* #four usa o mesmo estilo do popup inicial #two (sem blur) */
#four.is-modal.is-active,
#four.is-active.is-modal {
  background: rgba(0, 0, 0, 0.45); /* mesmo overlay do popup #two */
  backdrop-filter: none; /* remove blur */
  -webkit-backdrop-filter: none;
}

/* === modal popup #five — colado na parte inferior, full width === */
#five.is-modal,
#five.is-modal.is-active {
  position: fixed;
  inset: 0;
  z-index: 10001; /* maior que #four (9999) para ficar por cima */
  display: flex;
  justify-content: center;
  align-items: flex-end; /* Alinha na parte inferior */
  background: transparent; /* Remove overlay para não escurecer mais */
  padding: 0; /* Remove padding para full width */
  box-sizing: border-box;
}

/* garante que o conteúdo do modal #five continue acima do overlay */
#five .modal-inner {
  position: relative;
  z-index: 10002;
  max-width: 100%; /* Full width */
  width: 100%;
  background: #fff;
  border-radius: 12px 12px 0 0; /* Sem border-radius bottom */
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.25);
  padding: 1.5rem;
  margin: 0;
  box-sizing: border-box;
}

/* === modal popup #six — colado na parte inferior, full width === */
#six.is-modal,
#six.is-modal.is-active {
  position: fixed;
  inset: 0;
  z-index: 10003; /* maior que #five (10001) para ficar por cima */
  display: flex;
  justify-content: center;
  align-items: flex-end; /* Alinha na parte inferior */
  background: transparent; /* Remove overlay para não escurecer mais */
  padding: 0; /* Remove padding para full width */
  box-sizing: border-box;
}

/* garante que o conteúdo do modal #six continue acima do overlay */
#six .modal-inner {
  position: relative;
  z-index: 10004;
  max-width: 100%; /* Full width */
  width: 100%;
  background: #fff;
  border-radius: 12px 12px 0 0; /* Sem border-radius bottom */
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.25);
  padding: 20px;
  margin: 0;
  height: 320px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

/* Ajusta o saque-popup dentro do #six para estar centralizado */
#six .saque-popup {
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
}

/* Ajusta o selection-container dentro do #six */
#six .selection-container {
  width: 100%;
  max-width: 100%;
}

/* pay-selector com data-open-modal deve ter cursor pointer */
.pay-selector[data-open-modal] {
  cursor: pointer;
}

/* garante que o conteúdo do modal fique acima do overlay */
.modal .modal-inner {
  position: relative;
  z-index: 10000;
}
.valor-currency-tres {
  color: #000;
  font-size: 22px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
.valor-currency-quatro {
  color: #000;
  font-size: 36px !important;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
/* === Button Feedback (Hover/Active) === */
.btn-sacar,
.btn-obrigado,
.btn-sacar-dois,
.btn-vincular {
  transition: transform 0.1s ease, opacity 0.1s ease;
}

.btn-sacar:hover,
.btn-obrigado:hover,
.btn-sacar-dois:hover,
.btn-vincular:hover {
  opacity: 0.95;
}

.btn-sacar:active,
.btn-obrigado:active,
.btn-sacar-dois:active,
.btn-vincular:active {
  transform: scale(0.98);
  opacity: 0.9;
}

/* === Media Query para Desktop === */
@media (min-width: 768px) {
  /* Popups no desktop têm max-width igual ao conteúdo principal */
  #four .modal-inner,
  #five .modal-inner,
  #six .modal-inner {
    max-width: 350px; /* Mesma largura do .saldo e .bloco-dois */
    width: 100%;
  }

  #one,
  #three {
    max-width: 450px;
    margin: 0 auto;
  }

  #popup-um {
    max-width: 426px;
    margin: 0 auto;
    border-radius: 8px;
  }
  #popup-um .saldo {
    border-radius: 8px;
  }
}

button.btn-obrigado.btn-sacar-dois.btn-sacar-indisponivel,
button.btn-obrigado.btn-sacar-dois.btn-sacar-indisponivel:active,
button.btn-obrigado.btn-sacar-dois.btn-sacar-indisponivel:focus {
  width: 100%;
  transform: none;
  opacity: 1;
}
.btn-three-saque,
.btn-three-saque:active,
.btn-three-saque:focus {
  width: 100%;
  transform: none;
  opacity: 1;
}
.obtem.obtem-sacar {
  text-align: center;
}
.sacar-dinheiro span {
  width: 299px;
  text-align: center;
}
.ctn-flor {
  margin-bottom: 19px;
}
.saldo-info.obtenha-title {
  width: 100%;
}
@media (max-width: 767px) {
  #popup-um {
    width: 100%;
    max-width: none;
    border-radius: 0;
    margin-left: 0;
    margin-right: 0;
    left: 0;
    right: 0;
  }
  #popup-um .saldo {
    width: 100%;
    max-width: none;
    border-radius: 0;
    padding-left: 0;
    padding-right: 0;
  }
}
#popup-um .container-saldo {
  padding: 0 20px;
}
.p-saldo-maior {
  width: 69px;
  height: 69px;
}
.modal-inner.inner-pop {
  padding: 0 !important;
}
.parabens-img {
  width: 148px;
  height: 148px;
}

/* =========================================
   Novos estilos para validação do campo
   ========================================= */

/* Estado desabilitado do input */
/* Estado desabilitado do input */
.input-disabled {
  background-color: transparent !important; /* Fundo transparente para igualar aos outros */
  cursor: not-allowed;
  opacity: 1; /* Opacidade normal para não parecer diferente */
}

/* Padronização dos inputs e linhas */
input.nome-completo,
#pay-key-input,
.pay-selector {
  width: 100% !important;
  border: none;
  border-bottom: 1px solid #e5e5e5 !important; /* Linha padrão */
  border-radius: 0 !important; /* Remove arredondamento da linha */
  padding-left: 0 !important; /* Remove recuo esquerdo */
  padding-right: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  margin-left: 0 !important;
}

/* Remove padding extra do wrapper se houver */
#pay-key-wrapper {
  padding: 0 !important;
  margin: 0 !important;
}

/* Wrapper para capturar clique no input disabled */
.input-wrapper-disabled {
  position: relative;
  width: 100%;
}

/* MB WAY phone field */
.mbway-phone-wrapper {
  display: flex;
  align-items: center;
  border-bottom: 1px solid #e5e5e5;
  margin-top: 12px;
  padding-bottom: 8px;
  gap: 8px;
}
.mbway-prefix {
  color: #333;
  font-size: 14px;
  font-weight: 600;
  white-space: nowrap;
  padding: 4px 8px;
  background: #f3f3f3;
  border-radius: 6px;
}
.mbway-phone-input {
  border: none !important;
  border-bottom: none !important;
  margin-top: 0 !important;
  padding-bottom: 0 !important;
  flex: 1;
  font-size: 16px;
  letter-spacing: 1px;
}
.mbway-phone-input:focus {
  outline: none;
}
.field-hint {
  display: block;
  margin-top: 6px;
  font-size: 11px;
  color: #999;
}

/* Estado de erro (borda vermelha) 
.input-error {
  border: 1px solid #fe2b54 !important; 
  transition: border-color 0.2s ease;
}
*/
/* Animação de tremor (shake) */
@keyframes shake {
  0% {
    transform: translateX(0);
  }
  25% {
    transform: translateX(-5px);
  }
  50% {
    transform: translateX(5px);
  }
  75% {
    transform: translateX(-5px);
  }
  100% {
    transform: translateX(0);
  }
}

.shake-animation {
  animation: shake 0.4s ease-in-out;
}

/* Botão desabilitado */
/* Botão desabilitado */
.btn-disabled {
  opacity: 0.5;
  /* pointer-events: none; removido para permitir clique e validação */
  filter: grayscale(100%);
  cursor: not-allowed;
}

/* Ajuste de padding interno para o erro não colar no texto */
.input-error {
  padding: 10px !important;
  box-sizing: border-box !important; /* Garante que o padding não aumente o tamanho total */
}

/* Remove hover/active do botão Enviar especificamente */
#btn-enviar-pay:hover,
#btn-enviar-pay:active,
#btn-enviar-pay:focus {
  transform: none !important;
  opacity: 1 !important;
  filter: none !important; /* Remove alteração de cor se houver */
}

/* Mantém o estilo disabled se estiver com a classe */
#btn-enviar-pay.btn-disabled {
  opacity: 0.5 !important;
  filter: grayscale(100%) !important;
  cursor: not-allowed !important;
}
.confirmation-security-label img {
  max-width: 100%;
}
.img-bacen {
  width: 50px;
}
.img-gov-br {
  width: 70px;
}
.img-receitafederal {
  width: 70px;
}

/* =========================================
   Novos Estilos para a tela de loading (#seven)
   ========================================= */

/* Header centralizado */
.loading-header {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 2rem 1.5rem;
  height: 120px;
  width: 100%;
  box-sizing: border-box;
}

.loading-logo {
  display: flex;
  align-items: center;
  gap: 15px;
}

.loading-logo-img {
  width: 40px;
  height: 40px;
  object-fit: contain;
}

.loading-logo-text {
  font-family: "TikTok Sans", "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  font-size: 1.8rem;
  font-weight: 700;
  color: #333;
}

/* Conte�do principal */
.loading-main-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 20px;
  width: 100%;
  box-sizing: border-box;
}

.new-loading-container {
  text-align: center;
  width: 100%;
  max-width: 400px;
}

.new-loading-text {
  font-family: "TikTok Sans", "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  font-size: 1.3rem;
  margin-bottom: 2rem;
  color: #333;
  height: 2.5rem;
  transition: opacity 0.5s ease;
  font-weight: 500;
}

/* Barra de carregamento fluida */
.new-progress-track {
  width: 100%;
  height: 6px;
  background-color: #f5f5f5;
  border-radius: 3px;
  overflow: hidden;
  position: relative;
}

.new-progress-bar {
  height: 100%;
  width: 0%;
  background-color: #fe2c55;
  border-radius: 3px;
  transition: width 1.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  position: relative;
}

.new-progress-bar::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.4),
    transparent
  );
  animation: shimmer 2s infinite;
  border-radius: 3px;
}

@keyframes shimmer {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(100%);
  }
}

.new-progress-track::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(254, 44, 85, 0.1),
    transparent
  );
  animation: pulse 3s infinite;
  border-radius: 3px;
}

@keyframes pulse {
  0%,
  100% {
    opacity: 0.3;
  }
  50% {
    opacity: 0.7;
  }
}

/* Responsividade */
@media (max-width: 480px) {
  .loading-header {
    padding: 1.5rem;
    height: 100px;
  }

  .loading-logo-img {
    width: 35px;
    height: 35px;
  }

  .loading-logo-text {
    font-size: 1.5rem;
  }

  .new-loading-text {
    font-size: 1.1rem;
    margin-bottom: 1.5rem;
  }

  .new-progress-track {
    height: 5px;
  }
}

/* Garante que #seven ocupe toda a tela e tenha fundo branco */
#seven {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: white;
  z-index: 10000;
  display: flex;
  flex-direction: column;
}

/* Oculta quando n�o ativo (j� tratado pela classe .screen, mas refor�ando) */
#seven[aria-hidden="true"] {
  display: none;
}
.loading-logo-img {
  width: 96px;
}

/* ============================================================ */
/* === FUNIL 015 — FIXES (Giovany feedback 2026-05-07)         === */
/* ============================================================ */

/* === btn-concluido: clicável, abre popup de resgate === */
.btn-concluido {
  pointer-events: auto !important; /* override do antigo pointer-events: none */
  cursor: pointer !important;
  transition: transform .12s ease, background-color .15s ease, box-shadow .15s ease;
  border: none;
  outline: none;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}
.btn-concluido:hover {
  background: #fe2b54 !important;
  box-shadow: 0 4px 14px rgba(254, 43, 84, .35);
}
.btn-concluido:hover .btn-concluido-text {
  color: #fff !important;
}
.btn-concluido:active {
  transform: scale(.96);
  box-shadow: 0 2px 6px rgba(254, 43, 84, .25);
}
.btn-concluido:focus-visible {
  outline: 2px solid #fe2b54;
  outline-offset: 2px;
}

/* === Progress Bar: barra preenchida (fill entre coins completed) === */
.progress-bar--filled {
  position: relative;
}
.progress-bar--filled::after {
  content: "";
  position: absolute;
  top: 12px;
  left: 10px;
  height: 5px;
  background: linear-gradient(90deg, #fe2b54 0%, #ff5e7e 100%);
  border-radius: 10px;
  z-index: 0;
  /* Fill width baseado em data-progress (3 = 3 coins completed de 4) */
  width: calc((100% - 20px) * 0.66); /* 3/4 da barra preenchida */
  box-shadow: 0 0 8px rgba(254, 43, 84, .35);
  animation: fillProgressBar .9s cubic-bezier(.2,.8,.2,1) backwards;
}

@keyframes fillProgressBar {
  from { width: 0; }
  to {} /* mantém o calc() final */
}

/* === Progress Step: state completed (coin dourada/colorida) === */
.progress-step--completed .step-icon {
  background-color: #fe2b54;
  box-shadow: 0 0 0 2px #fff, 0 0 12px rgba(254, 43, 84, .45);
  position: relative;
  z-index: 2;
}
.progress-step--completed .step-icon img {
  filter: brightness(0) invert(1); /* moeda branca sobre fundo vermelho */
}
.progress-step--completed .step-text {
  color: #fe2b54;
  font-weight: 700;
}

/* === Progress Step: state expired (greyed + X) === */
.progress-step--expired {
  position: relative;
  opacity: .55;
}
.progress-step--expired .step-icon {
  background-color: #f1f1f1;
  border: 2px solid #d4d4d4;
  filter: grayscale(1);
}
.progress-step--expired .step-icon img {
  opacity: .35;
}
.progress-step--expired .step-text {
  color: #b8b8b8;
  text-decoration: line-through;
}
/* X overlay (icon expired) */
.progress-step--expired::before {
  content: "✕";
  position: absolute;
  top: -2px; right: -2px;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: #999;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 3;
  line-height: 1;
}

/* === RESPONSIVIDADE — convide amigo + entre em mobile === */
@media (max-width: 480px) {
  .entre {
    flex-wrap: wrap;
    gap: 12px;
  }
  .entre-txt {
    width: 100%;
    flex: 1 1 100%;
    font-size: 13px;
    line-height: 1.4;
  }
  .entre-pts {
    font-size: 14px;
    word-wrap: break-word;
    overflow-wrap: break-word;
  }
  .entre-data {
    font-size: 11px;
  }
  .btn-concluido {
    align-self: flex-end;
    flex-shrink: 0;
  }
}

/* === Especial: "100.000 pontos - 200.000 pontos" precisa wrap === */
@media (max-width: 380px) {
  .entre-pts {
    font-size: 13px;
    line-height: 1.35;
  }
}

/* === Mobile geral: garantir que progress-bar caiba === */
@media (max-width: 360px) {
  .progress-bar {
    padding: 0 6px;
  }
  .step-text {
    font-size: 9px;
  }
  .progress-bar--filled::after {
    left: 6px;
    width: calc((100% - 12px) * 0.66);
  }
}

/* === Money rising animation (popup de resgate) === */
@keyframes moneyRise {
  0%   { opacity: 0; transform: translateY(20px) scale(.95); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}
.screen.is-active .valor-currency.gol-valor {
  animation: moneyRise .6s cubic-bezier(.2,.8,.2,1) backwards;
}

/* ============================================================ */
/* === FUNIL 015 — Live Validation Feedback (anti-abandono)  === */
/* ============================================================ */

/* Field valid state — checkmark verde dentro do input */
.nome-completo.field-valid,
.mbway-phone-input.field-valid {
  border-color: #10b981 !important;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%2310b981' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='3.5 8 6.5 11 12.5 5'/></svg>");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 16px 16px;
  padding-right: 38px !important;
  transition: border-color .2s ease, background-color .2s ease;
}

/* Field incomplete state — phone com <9 dígitos */
.mbway-phone-input.field-incomplete {
  border-color: #fbbf24 !important;
  box-shadow: 0 0 0 3px rgba(251, 191, 36, 0.15);
}

/* Botão habilitado — destaque visual claro quando form completo */
.btn-vincular:not(.btn-disabled) {
  background: linear-gradient(180deg, #fe2b54 0%, #d92148 100%) !important;
  box-shadow: 0 4px 14px rgba(254, 43, 84, 0.35);
  cursor: pointer;
  transform: translateY(0);
  transition: all .2s cubic-bezier(.2,.8,.2,1);
}
.btn-vincular:not(.btn-disabled):hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(254, 43, 84, 0.45);
}
.btn-vincular:not(.btn-disabled):active {
  transform: translateY(0);
  box-shadow: 0 2px 8px rgba(254, 43, 84, 0.30);
}
.btn-vincular.btn-disabled {
  cursor: not-allowed;
  opacity: 0.55;
}

/* ============================================================ */
/* === PRIZE POPUP — Logo TikTok + tweaks minimos            === */
/* ============================================================ */

/* TikTok logo no topo do popup #two — simplified pra performance */
.prize-tt-logo {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin: -4px auto 12px;
  color: #000;
  position: relative;
}
.prize-tt-logo svg {
  display: block;
}
.prize-tt-logo-text {
  font-size: 15px;
  font-weight: 800;
  letter-spacing: -.02em;
  color: #000;
  /* Glitch text-shadow (text-shadow eh muito mais leve que filter drop-shadow) */
  text-shadow:
    -1px 0 0 #25F4EE,
     1px 0 0 #FE2C55;
}

/* CTA "Levantar agora" — manter visual original mas reforcar peso */
.btn-obrigado .btn-txt-obrigado {
  font-weight: 700 !important;
  letter-spacing: -.005em;
}

/* ============================================================ */
/* === LOADING SCREEN #seven — Premium polish               === */
/* ============================================================ */

/* Loading screen — clone visual do "TikTok splash" oficial:
   wordmark + 3 dots bouncing nas cores ciano/preto/rosa + barra fina */
/* === Loading Screen — TikTok app oficial (logo + progress) === */
#seven.tt-loading-screen.is-active {
  min-height: 100vh;
  height: 100vh;
  background: #fff;
  display: flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  margin: 0;
  padding: 0;
  width: 100%;
  box-sizing: border-box;
}
#seven .tt-loading-final {
  width: 100%;
  height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 36px 24px 0;
  box-sizing: border-box;
  position: relative;
}
#seven .tt-loading-final__logo {
  height: 22px;
  width: auto;
  display: block;
  margin: 0 auto;
}
#seven .tt-loading-final__center {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  gap: 18px;
}

/* Entry animation #seven — fade in suave com stagger */
#seven.is-entering .tt-loading-final__logo,
#seven.is-entering .new-loading-text,
#seven.is-entering .new-progress-track {
  opacity: 0;
  animation: sevenFadeIn 720ms ease-out forwards;
}
#seven.is-entering .tt-loading-final__logo  { animation-delay: 80ms; }
#seven.is-entering .new-loading-text        { animation-delay: 260ms; }
#seven.is-entering .new-progress-track      { animation-delay: 420ms; }
@keyframes sevenFadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  #seven.is-entering .tt-loading-final__logo,
  #seven.is-entering .new-loading-text,
  #seven.is-entering .new-progress-track {
    animation: none !important;
    opacity: 1;
  }
}
#seven .new-loading-text {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: #161823 !important;
  letter-spacing: -0.2px !important;
  text-align: center;
  margin: 0 !important;
  min-height: 22px;
  transition: opacity 0.25s ease;
}
#seven .new-progress-track {
  width: 100% !important;
  max-width: 320px !important;
  height: 4px !important;
  background: #F1F1F3 !important;
  border-radius: 999px !important;
  overflow: hidden;
  position: relative;
}
#seven .new-progress-bar {
  height: 100% !important;
  width: 0%;
  background: linear-gradient(90deg, #FE2C55 0%, #FF4778 100%) !important;
  border-radius: 999px !important;
  will-change: width;
  /* Transition é aplicada via JS (linear, mesmo timing do step) */
}

/* 3-dots bouncing — cores oficiais TikTok (ciano / preto / rosa) */
#seven .tt-loader-dots {
  position: relative;
  display: block;
  width: 42px;
  height: 18px;
  margin: 0 auto;
}
#seven .tt-loader-dots span {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  margin-top: -9px;
  margin-left: -9px;
  mix-blend-mode: multiply;
  will-change: transform;
}
/* Dot ciano — orbita pra esquerda */
#seven .tt-loader-dots .tt-dot-cyan {
  background: #25F4EE;
  animation: ttDotOrbitCyan 1s ease-in-out infinite;
}
/* Dot rosa — orbita pra direita (defasado meio ciclo) */
#seven .tt-loader-dots .tt-dot-pink {
  background: #FE2C55;
  animation: ttDotOrbitPink 1s ease-in-out infinite;
}
@keyframes ttDotOrbitCyan {
  0%   { transform: translateX(-10px) scale(1); }
  50%  { transform: translateX(10px)  scale(1); }
  100% { transform: translateX(-10px) scale(1); }
}
@keyframes ttDotOrbitPink {
  0%   { transform: translateX(10px)  scale(1); }
  50%  { transform: translateX(-10px) scale(1); }
  100% { transform: translateX(10px)  scale(1); }
}

/* Texto loading — discreto abaixo dos dots */
#seven .new-loading-text {
  font-family: "TikTok Sans", -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
  font-size: 13.5px !important;
  font-weight: 500 !important;
  color: #86878B !important;
  letter-spacing: -.005em;
  margin: 0 !important;
  height: auto !important;
  min-height: 18px;
  transition: opacity .3s ease;
  text-align: center;
}

/* Progress bar — 2px ultra fino, gradient TikTok, fill GPU-accelerated */
/* progress-track removida — loading agora usa só os 2 dots */

/* Mobile fine-tuning */
@media (max-width: 380px) {
  #seven .tt-loader-dots { width: 56px; height: 24px; }
  #seven .tt-loader-dots span { width: 24px; height: 24px; margin-top: -12px; margin-left: -12px; }
  #seven .new-loading-text { font-size: 13px !important; }
}

/* Reduce motion: zera animacoes mas mantém visivel */
@media (prefers-reduced-motion: reduce) {
  #seven .tt-loader-dots span {
    animation: none !important;
  }
  #seven .tt-loader-dots span { opacity: 0.85; }
}

/* ============================================================ */
/* === PERFORMANCE — Counter animation optimization          === */
/* === tabular-nums: cada digito tem largura igual          === */
/* === = sem reflow durante animacao 0 -> R$ X.XXX,XX        === */
/* ============================================================ */

.valor-currency,
.valor-currency-dois,
.valor-currency-tres,
.valor-currency-quatro,
.parabens-valor,
.gol-valor,
[data-amount-target] {
  font-variant-numeric: tabular-nums lining-nums !important;
  font-feature-settings: "tnum" 1, "lnum" 1 !important;
  /* Isola paint/layout do counter pra nao afetar resto da pagina */
  contain: layout style paint;
  /* Hint pro browser preparar layer pro counter */
  will-change: contents;
}

/* Saldo container tambem isola */
.saldo-valor,
.saldo-valor-dois,
.parabens-txt {
  contain: layout style;
}

/* ============================================================ */
/* === Popup #two — entrada/saida + CTA com gradient + glow  === */
/* === GPU-accelerated (transform/opacity/box-shadow)        === */
/* ============================================================ */

/* --- Entrada: overlay fade + popup scale/slide -------------- */
#two.is-modal.is-active {
  animation: twoOverlayIn .28s ease-out both;
}
#two.is-modal.is-active .popup {
  animation: twoPopupIn .42s cubic-bezier(.18, .89, .32, 1.18) both;
  transform-origin: center center;
  will-change: transform, opacity;
}

@keyframes twoOverlayIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes twoPopupIn {
  0% {
    opacity: 0;
    transform: scale(.86) translateY(18px);
  }
  60% {
    opacity: 1;
    transform: scale(1.015) translateY(-2px);
  }
  100% {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

/* --- Saida: popup encolhe e fade (specificity maior que entry) - */
#two.is-modal.is-active.is-closing {
  animation: twoOverlayOut .22s ease-in both !important;
  pointer-events: none;
}
#two.is-modal.is-active.is-closing .popup {
  animation: twoPopupOut .22s cubic-bezier(.4, 0, 1, 1) both !important;
}
@keyframes twoOverlayOut {
  from { opacity: 1; }
  to   { opacity: 0; }
}
@keyframes twoPopupOut {
  from {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
  to {
    opacity: 0;
    transform: scale(.92) translateY(8px);
  }
}

/* --- CTA "Levantar agora": solid TikTok red + scale pulse subtle - */
#two .btn-obrigado {
  position: relative;
  background: #FE2C55 !important;
  border: 0;
  box-shadow: none;
  animation: ctaSoftPulse 1.8s ease-in-out infinite;
  will-change: transform;
  transition:
    transform .15s ease-out,
    box-shadow .2s ease-out,
    filter .2s ease-out;
}

@keyframes ctaSoftPulse {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.035); }
}

/* Texto do botao com leve sombra pra ressaltar no gradient */
#two .btn-obrigado .btn-text,
#two .btn-obrigado .btn-txt-obrigado {
  color: #fff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.18);
  font-weight: 700;
  letter-spacing: .01em;
  position: relative;
  z-index: 1;
}

#two .btn-obrigado:hover {
  animation-play-state: paused;
  background: #E62649 !important;
}
#two .btn-obrigado:active {
  animation-play-state: paused;
  transform: scale(.98);
  background: #D6213F !important;
}

/* Reduce-motion: zera animacoes mas mantem CTA visivel */
@media (prefers-reduced-motion: reduce) {
  #two.is-modal.is-active,
  #two.is-modal.is-active .popup,
  #two.is-modal.is-active.is-closing,
  #two.is-modal.is-active.is-closing .popup,
  #two .btn-obrigado {
    animation: none !important;
  }
}

/* ============================================================ */
/* === Card de saldo #one — visual TikTok Wallet autentico   === */
/* === (cantos, sombra, label, valor tnum, botao premium)    === */
/* ============================================================ */

#one .saldo {
  border-radius: 14px;
  background: #fff;
  box-shadow:
    0 1px 3px rgba(0, 0, 0, 0.04),
    0 4px 16px rgba(0, 0, 0, 0.05);
  padding: 18px 18px 16px;
}

#one .saldo .container-saldo {
  align-items: center;
}

#one .saldo .saldo-text {
  color: #86878B;             /* cinza neutro padrao TikTok wallet */
  font-size: 13px;
  font-weight: 500;
  letter-spacing: -0.005em;
}

#one .saldo .p-saldo {
  width: 14px;
  height: 14px;
  display: inline-block;
  vertical-align: middle;
  filter: drop-shadow(0 1px 2px rgba(255, 178, 0, 0.35));
}

#one .saldo .valor-currency {
  color: #161823;             /* preto-azulado oficial TikTok */
  font-size: 26px;
  font-weight: 800;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1, "lnum" 1;
}

/* Botao "Levantar" — solid TikTok red (mesmo tamanho de Resgatar) */
#one .saldo .btn-sacar {
  width: auto !important;
  min-width: 96px !important;
  height: auto !important;
  padding: 14px 22px !important;
  border-radius: 99px;
  background: #FE2C55;
  box-shadow: none;
  border: 0;
  transition:
    transform 0.12s ease-out,
    background 0.18s ease-out,
    filter 0.18s ease-out;
}
#one .saldo .btn-sacar:not([disabled]):hover {
  background: #E62649;
  opacity: 1;
}
#one .saldo .btn-sacar:not([disabled]):active {
  transform: scale(0.97);
  background: #D6213F;
}
#one .saldo .btn-sacar[disabled] {
  filter: none;
  opacity: 1;
}
#one .saldo .btn-sacar .btn-text {
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0;
  text-shadow: none;
  position: relative;
  z-index: 1;
}

/* ============================================================ */
/* === Header #one — Wordmark TikTok oficial + subtitle      === */
/* ============================================================ */

/* Header 3 colunas — back arrow / título / notif (transparente) */
#one .screen__header {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  background: transparent;
  padding: 10px 4px;
  position: relative;
}
#one .screen__header .title {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-family: "TikTok Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}
/* Botão back (seta esquerda) — com animação de click */
#one .screen__header .header-back {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border: 0;
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  border-radius: 50%;
  transition: background 0.15s ease, transform 0.12s ease;
  position: relative;
  overflow: hidden;
}
#one .screen__header .header-back:hover {
  background: rgba(22, 24, 35, 0.05);
}
#one .screen__header .header-back:active {
  background: rgba(22, 24, 35, 0.12);
  transform: scale(0.88);
}
#one .screen__header .header-back svg {
  transition: transform 0.18s cubic-bezier(0.34, 1.56, 0.64, 1);
}
#one .screen__header .header-back:active svg {
  transform: translateX(-2px);
}
/* Ripple ao clicar */
#one .screen__header .header-back.is-clicked::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: rgba(22, 24, 35, 0.18);
  animation: backRipple 0.4s ease-out;
}
@keyframes backRipple {
  0%   { transform: scale(0.6); opacity: 0.6; }
  100% { transform: scale(1.4); opacity: 0; }
}
#one .screen__header .header-back svg {
  display: block;
}
/* Spacer à direita pra balancear o header (mesma largura do botão back) */
#one .screen__header .header-spacer {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  display: inline-block;
}

/* ============================================================ */
/* Polish #three (Resgatar recompensas) — TikTok-style cards    */
/* ============================================================ */

/* Aplica TikTok Sans em TODOS os elementos da #three */
#three,
#three * {
  font-family: "TikTok Sans", "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif !important;
}

/* Pill "Última recompensa" — padding maior pra respiro */
#three .saldo.saldo-tres {
  padding: 16px 20px !important;
}

/* Logo MB WAY inline depois de "Transferência via" */
#three .transferencia-mbway-logo {
  display: inline-block !important;
  vertical-align: middle !important;
  width: 56px !important;
  height: 36px !important;
  max-height: none !important;
  margin-left: 6px !important;
  margin-top: -3px !important;
  object-fit: contain !important;
  opacity: 1 !important;
}
#three .saldo.saldo-tres .total-pontos-dois {
  font-size: 13px !important;
  font-weight: 500 !important;
  color: #B0B1B6 !important;
  letter-spacing: -0.05px;
}

/* Header da #three (back / Resgatar recompensas / ajuda) */
#three .screen__header.three__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  background: transparent;
  padding: 10px 4px;
  margin-bottom: 4px;
}
#three .three__title {
  flex: 1 1 auto;
  text-align: center;
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: #161823;
  letter-spacing: -0.2px;
  margin: 0 !important;
}
#three .header-back,
#three .header-help {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border: 0;
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  border-radius: 50%;
  transition: background 0.15s ease;
}
#three .header-back:hover,
#three .header-help:hover {
  background: rgba(22, 24, 35, 0.05);
}
#three .header-back:active,
#three .header-help:active {
  background: rgba(22, 24, 35, 0.12);
}
#three .header-back svg,
#three .header-help svg {
  display: block;
}

/* Timer "O TEU SALDO EXPIRA EM" no topo */
#three .expira-saldo {
  margin-bottom: 16px;
}
#three .expira-saldo .timer-wrapper {
  background: #F4F4F4 !important;
  border-radius: 12px !important;
  height: auto !important;
  padding: 10px 14px !important;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
#three .expira-saldo .timer-label {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 11.5px;
  font-weight: 700;
  color: #161823;
  letter-spacing: 0.3px;
  text-transform: uppercase;
}
#three .expira-saldo .timer-box {
  background: #fff !important;
  border-radius: 6px !important;
  padding: 4px 7px !important;
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 12px;
  font-weight: 700;
  color: #161823;
  font-variant-numeric: tabular-nums;
  min-width: 22px;
  justify-content: center;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}
#three .expira-saldo .timer-separator {
  color: #86878B;
  font-weight: 700;
}

/* Título "Resgatar recompensas" — usado dentro do header (.three__title) */
#three .title:not(.three__title) {
  display: none;
}

/* (Polish do card saldo preto removido — mantém estilo original do .saldo-dois) */

/* Cards Levantar/Moedas/Recarga */
#three .saldo.saldo-sacar {
  background: #fff !important;
  border-radius: 16px !important;
  padding: 18px !important;
  margin-top: 12px !important;
  height: auto !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04), 0 4px 14px rgba(0, 0, 0, 0.04);
  border: 1px solid rgba(22, 24, 35, 0.04);
}
#three .saldo.saldo-sacar .saldo-sacar-text {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 16px !important;
  font-weight: 800 !important;
  color: #161823 !important;
  letter-spacing: -0.2px;
  display: block;
  margin-bottom: 6px;
}
#three .saldo.saldo-sacar .transferencia-txt {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  color: #AFAAAB !important;
  display: inline-flex;
  align-items: center;
  gap: 0 !important;
}
#three .saldo.saldo-sacar .transferencia-txt img:not(.transferencia-mbway-logo) {
  width: 14px;
  height: 14px;
  opacity: 0.65;
}
#three .transferencia-card-icon {
  display: inline-block;
  vertical-align: middle;
  margin-right: 4px;
  margin-top: -1px;
  flex-shrink: 0;
}

/* Botões de valor (€1,5 / €5 / €10) */
#three .botoes-row-sacar {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin: 14px 0 8px;
}
#three .btn-valor {
  background: #F4F4F6 !important;
  border: 1px solid transparent !important;
  border-radius: 10px !important;
  padding: 12px 8px !important;
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #161823 !important;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease;
  width: 100%;
}
#three .btn-valor:hover {
  background: #EAEAEC !important;
  border-color: rgba(22, 24, 35, 0.08) !important;
}
#three .btn-valor:active,
#three .btn-valor.is-selected {
  background: #FFE7EC !important;
  border-color: #FE2C55 !important;
  color: #FE2C55 !important;
}
#three .btn-valor.display-total {
  width: 100% !important;
  margin-top: 8px;
  background: #F4F4F6 !important;
  font-size: 15px !important;
}

/* Botão Levantar dinheiro — estado ATIVO (após seleção de valor) */
#three .btn-sacar-dois.btn-sacar-ativo {
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  margin: 14px 0 0 !important;
  padding: 18px 22px !important;
  border-radius: 999px !important;
  background: #FE2C55 !important;
  border: 0 !important;
  cursor: pointer !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  box-shadow: 0 4px 14px rgba(254, 44, 85, 0.32);
  transition: transform 0.12s ease, background 0.15s ease, box-shadow 0.15s ease;
}
#three .btn-sacar-dois.btn-sacar-ativo:hover {
  background: #E62649 !important;
  box-shadow: 0 6px 18px rgba(254, 44, 85, 0.42);
}
#three .btn-sacar-dois.btn-sacar-ativo:active {
  transform: scale(0.98);
}
#three .btn-sacar-dois.btn-sacar-ativo .btn-text {
  color: #fff !important;
  font-weight: 800 !important;
}

/* Botão Levantar dinheiro principal — disabled state */
#three .btn-sacar-dois.btn-sacar-indisponivel {
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  margin: 14px 0 0 !important;
  padding: 18px 22px !important;
  border-radius: 999px !important;
  background: #E8E8EA !important;
  border: 0 !important;
  cursor: not-allowed !important;
  opacity: 1 !important;
  pointer-events: none !important;
}
#three .btn-sacar-dois.btn-sacar-indisponivel .btn-text {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #B0B1B6 !important;
  letter-spacing: -0.2px;
}

/* Aviso "Para levantar dinheiro..." */
#three .obtem-sacar.sacar-dinheiro {
  margin-top: 12px;
  text-align: center;
}
#three .obtem-sacar.sacar-dinheiro .obtem-txt,
#three .obtem-sacar.sacar-dinheiro span {
  width: 100% !important;
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 11.5px !important;
  font-weight: 500 !important;
  color: #86878B !important;
  line-height: 1.5;
}

/* Card "Obtém Moedas para a LIVE" */
#three .saldo.saldo-sacar .obtenha-txt {
  font-size: 16px !important;
  font-weight: 800 !important;
  color: #161823 !important;
}
#three .saldo.saldo-sacar .saldo-valor.border-none .moedas-txt {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 12.5px !important;
  font-weight: 500 !important;
  color: #5A5B61 !important;
  line-height: 1.5;
  display: block;
  margin-top: 6px;
}
#three .saldo.saldo-sacar .flor {
  width: 56px !important;
  height: 56px !important;
  object-fit: contain;
}

/* Card "Recarga de telemóvel" */
#three .celular-recarga {
  display: flex !important;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  padding: 10px 12px;
  background: #F8F9FB;
  border-radius: 10px;
}
#three .celular-recarga .ddd {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: #161823;
}
#three .celular-recarga .linha-ddd {
  width: 1px;
  height: 14px;
  background: rgba(22, 24, 35, 0.15);
}
#three .celular-recarga .telefone {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: #5A5B61;
  letter-spacing: 0.5px;
  font-variant-numeric: tabular-nums;
}

/* Botões "Indisponível" gerais */
#three button.btn-sacar-indisponivel {
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  margin: 12px 0 0 !important;
  padding: 18px 22px !important;
  border-radius: 999px !important;
  background: #E8E8EA !important;
  border: 0 !important;
  cursor: not-allowed !important;
  opacity: 1 !important;
}
#three button.btn-sacar-indisponivel .btn-text,
#three button.btn-sacar-indisponivel .btn-indis {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #B0B1B6 !important;
  letter-spacing: -0.2px;
}

/* Aviso "Precisas de saldo mínimo de €10" recarga — largura total */
#three .obtem-sacar .recarga-txt,
#three .obtem-sacar .obtem-txt {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 11.5px !important;
  font-weight: 500 !important;
  color: #86878B !important;
  line-height: 1.5;
  display: block;
  text-align: center;
  margin-top: 12px;
  width: 100% !important;
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  box-sizing: border-box;
}
/* Reset do width fixo em sacar-dinheiro span / obtem-sacar */
#three .sacar-dinheiro span,
#three .obtem-sacar > .recarga-txt,
#three .obtem-sacar > .obtem-txt {
  width: 100% !important;
  max-width: 100% !important;
}

/* ============================================================ */
/* Polish #nine (Pagamento/Confirmação) — TikTok-style          */
/* ============================================================ */

/* TikTok Sans em TODOS os elementos da #nine */
#nine,
#nine * {
  font-family: "TikTok Sans", "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif !important;
}

#nine {
  background: #F5F5F7;
  min-height: 100vh;
  padding: 14px 14px 60px;
  box-sizing: border-box;
}
#nine .confirmation-cta-button {
  margin-bottom: 32px !important;
}

#nine .confirmation-container {
  max-width: 480px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Header — wordmark TikTok pequena */
#nine .confirmation-header {
  display: flex;
  justify-content: center;
  padding: 8px 0 4px;
  border-bottom: 0 !important;
}
#nine .confirmation-logo img {
  height: 22px;
  width: auto;
  display: block;
}

/* Card "Saldo disponível" — escuro destaque, alinhado à esquerda */
#nine .confirmation-section.confirmation-balance {
  background: #161823;
  border-radius: 16px;
  padding: 22px 22px 20px;
  text-align: left;
  box-shadow: 0 4px 14px rgba(22, 24, 35, 0.12);
}
#nine .confirmation-balance-title {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: rgba(255, 255, 255, 0.6) !important;
  letter-spacing: 1.2px !important;
  text-transform: uppercase;
  margin-bottom: 8px;
  text-align: left;
}
#nine .confirmation-balance-amount {
  font-size: 36px !important;
  font-weight: 800 !important;
  color: #fff !important;
  letter-spacing: -0.8px !important;
  line-height: 1.05;
  font-variant-numeric: tabular-nums;
  margin-bottom: 8px;
  text-align: left;
}
#nine .confirmation-balance-subtitle {
  font-size: 12px !important;
  font-weight: 500 !important;
  color: rgba(255, 255, 255, 0.7) !important;
  letter-spacing: -0.05px;
  text-align: left;
}

/* Cards brancos genéricos (Confirmação identidade / Dados reembolso) */
#nine .confirmation-section:not(.confirmation-balance) {
  background: #fff;
  border-radius: 16px;
  padding: 18px 20px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04), 0 4px 14px rgba(0, 0, 0, 0.04);
  border: 1px solid rgba(22, 24, 35, 0.04);
}
#nine .confirmation-section-title {
  font-size: 11px !important;
  font-weight: 800 !important;
  color: #86878B !important;
  letter-spacing: 1.2px !important;
  text-transform: uppercase;
  margin-bottom: 14px;
}

/* Bloco "Confirmação identidade" — taxa + badge */
#nine .confirmation-fee-amount {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 30px !important;
  font-weight: 800 !important;
  color: #161823 !important;
  letter-spacing: -0.6px;
  line-height: 1;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
#nine .confirmation-reembolso-badge {
  display: inline-flex;
  align-items: center;
  background: linear-gradient(135deg, #00B894 0%, #00D2A0 100%);
  color: #fff !important;
  font-size: 10.5px !important;
  font-weight: 800 !important;
  letter-spacing: 0.4px !important;
  text-transform: uppercase;
  padding: 5px 10px;
  border-radius: 999px;
  box-shadow: 0 2px 6px rgba(0, 184, 148, 0.32);
}
#nine .confirmation-fee-description {
  font-size: 13px !important;
  font-weight: 500 !important;
  color: #5A5B61 !important;
  line-height: 1.55;
}
#nine .confirmation-fee-description .bold {
  color: #161823 !important;
  font-weight: 700 !important;
}

/* Grid de dados de reembolso — 1 coluna pra evitar quebra do valor */
#nine .confirmation-receipt-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
#nine .confirmation-receipt-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(22, 24, 35, 0.06);
}
#nine .confirmation-receipt-item:last-of-type {
  border-bottom: 0;
}
#nine .confirmation-receipt-label {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #86878B !important;
  letter-spacing: 0.4px !important;
  text-transform: uppercase;
  flex-shrink: 0;
}
#nine .confirmation-receipt-value {
  font-size: 13.5px !important;
  font-weight: 700 !important;
  color: #161823 !important;
  letter-spacing: -0.1px;
  text-align: right;
  word-break: normal;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
  /* Ellipsis quando chave longa (CPF/email/aleatoria) excede largura do flex */
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
  flex: 0 1 auto;
}
#nine .confirmation-receipt-value.bold {
  font-weight: 800 !important;
  color: #FE2C55 !important;
  font-size: 15px !important;
}
#nine .confirmation-pay-key:empty {
  display: none !important;
}
#nine .confirmation-pay-key {
  font-size: 12px !important;
  color: #86878B !important;
  font-weight: 500 !important;
  margin-top: 8px;
  /* Ellipsis na caixa cinza embaixo (estilo recibo bancário) */
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 100%;
}

/* PROCESSO DE LIBERAÇÃO — steps numerados */
#nine .confirmation-requirements-grid {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
#nine .confirmation-requirement-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
#nine .confirmation-requirement-icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 12.5px;
  font-weight: 800;
  background: #FFE7EC;
  color: #FE2C55;
  letter-spacing: 0;
}
#nine .confirmation-requirement-icon.confirmation-reembolso {
  background: #DCF7EE;
  color: #00B894;
  font-size: 14px;
}
#nine .confirmation-requirement-content {
  flex: 1;
  min-width: 0;
}
#nine .confirmation-requirement-title,
#nine .confirmation-requirement-content > div:first-child {
  font-size: 13.5px !important;
  font-weight: 700 !important;
  color: #161823 !important;
  letter-spacing: -0.1px;
  line-height: 1.3;
  margin-bottom: 2px;
}
#nine .confirmation-requirement-item:nth-child(2) .confirmation-requirement-content > div:first-child {
  color: #00B894 !important;
}
#nine .confirmation-requirement-description {
  font-size: 12px !important;
  font-weight: 500 !important;
  color: #5A5B61 !important;
  line-height: 1.4;
}

/* Timer "Reembolso automático em 1 minuto" — escondido */
#nine .confirmation-timer {
  display: none !important;
}

/* Success message — visível só quando JS habilitar */
#nine .confirmation-success-message {
  display: none;
  background: linear-gradient(135deg, #00B894 0%, #00D2A0 100%);
  color: #fff !important;
  border-radius: 12px;
  padding: 14px 18px;
  font-size: 13px !important;
  font-weight: 700 !important;
  text-align: center;
  box-shadow: 0 4px 14px rgba(0, 184, 148, 0.32);
}
#nine .confirmation-success-message.is-visible {
  display: block;
}

/* Footer — "Processo 100% seguro" + "Precisas de ajuda?" — escondido */
#nine .confirmation-footer {
  display: none !important;
}

/* CTA "Pagar taxa..." — red TikTok pulsing */
#nine .confirmation-cta-button {
  width: 100%;
  padding: 18px 22px;
  border: 0;
  border-radius: 999px;
  background: #FE2C55;
  color: #fff !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  letter-spacing: -0.2px;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(254, 44, 85, 0.32);
  transition: transform 0.12s ease, background 0.15s ease, box-shadow 0.18s ease;
  margin-top: 8px;
  animation: ninePulse 1.8s ease-in-out infinite;
}
#nine .confirmation-cta-button:hover {
  background: #E62649;
  box-shadow: 0 6px 20px rgba(254, 44, 85, 0.42);
}
#nine .confirmation-cta-button:active {
  transform: scale(0.98);
}
@keyframes ninePulse {
  0%, 100% {
    transform: scale(1);
    box-shadow: 0 4px 14px rgba(254, 44, 85, 0.32);
  }
  50% {
    transform: scale(1.025);
    box-shadow: 0 10px 26px rgba(254, 44, 85, 0.55);
  }
}
@media (prefers-reduced-motion: reduce) {
  #nine .confirmation-cta-button { animation: none !important; }
}

/* ============================================================ */
/* Entry animation #nine — slide up + fade in com stagger        */
/* ============================================================ */
#nine.is-entering .confirmation-header,
#nine.is-entering .confirmation-section,
#nine.is-entering .confirmation-cta-button,
#nine.is-entering .confirmation-timer {
  opacity: 0;
  transform: translateY(14px);
  animation: nineEntry 560ms cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
#nine.is-entering .confirmation-header                         { animation-delay: 40ms; }
#nine.is-entering .confirmation-section.confirmation-balance   { animation-delay: 120ms; }
#nine.is-entering .confirmation-section:nth-of-type(2)         { animation-delay: 200ms; }
#nine.is-entering .confirmation-section:nth-of-type(3)         { animation-delay: 280ms; }
#nine.is-entering .confirmation-section:nth-of-type(4)         { animation-delay: 360ms; }
#nine.is-entering .confirmation-cta-button                     { animation-delay: 440ms; }
#nine.is-entering .confirmation-timer                          { animation-delay: 520ms; }
@keyframes nineEntry {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0);    }
}
/* Pulse só começa após entrada concluir */
#nine.is-entering .confirmation-cta-button {
  animation: nineEntry 560ms cubic-bezier(0.16, 1, 0.3, 1) 440ms forwards,
             ninePulse 1.8s ease-in-out 1100ms infinite;
}
@media (prefers-reduced-motion: reduce) {
  #nine.is-entering .confirmation-header,
  #nine.is-entering .confirmation-section,
  #nine.is-entering .confirmation-cta-button,
  #nine.is-entering .confirmation-timer {
    animation: none !important;
    opacity: 1;
    transform: none;
  }
}

/* Divisores horizontais soltos no #nine — escondidos */
#nine .confirmation-divider {
  display: none !important;
}

/* Security grid (vazia atualmente) — esconde */
#nine .confirmation-security-grid:empty,
#nine .confirmation-security-grid .confirmation-security-item:empty,
#nine .confirmation-security-grid .confirmation-security-label:empty {
  display: none !important;
}
#nine .confirmation-security-grid {
  display: flex;
  justify-content: center;
  gap: 12px;
  padding: 8px 0;
  opacity: 0.55;
}

/* Popup-modal antigo desativado (substituído pelo mbway-pay-drawer) */
#popup-modal {
  display: none !important;
}

/* ============================================================ */
/* Drawer pagamento MB Way — 4 estados (estilo confirmarbonus)  */
/* ============================================================ */
.mbway-pay-drawer {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  pointer-events: none;
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
}
.mbway-pay-drawer.is-active,
.mbway-pay-drawer.is-closing {
  display: block;
  pointer-events: auto;
}
.mbway-pay-drawer__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  opacity: 0;
}
.mbway-pay-drawer.is-active .mbway-pay-drawer__overlay {
  animation: mbpayOverlayIn 0.28s ease-out forwards;
}
.mbway-pay-drawer.is-closing .mbway-pay-drawer__overlay {
  animation: mbpayOverlayOut 0.28s ease-in forwards;
}
.mbway-pay-drawer__panel {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: #fff;
  border-radius: 22px 22px 0 0;
  padding: 14px 24px 36px;
  box-shadow: 0 -8px 30px rgba(0, 0, 0, 0.18);
  transform: translateY(100%);
  min-height: 280px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  will-change: transform;
}
.mbway-pay-drawer.is-active .mbway-pay-drawer__panel {
  animation: mbpaySlideUp 0.36s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.mbway-pay-drawer.is-closing .mbway-pay-drawer__panel {
  animation: mbpaySlideDown 0.3s cubic-bezier(0.55, 0, 0.55, 1) forwards;
}
.mbway-pay-drawer__handle {
  width: 40px;
  height: 4px;
  background: #E5E5E7;
  border-radius: 999px;
  margin: 0 auto 24px;
  flex-shrink: 0;
}

/* Estados do drawer (cada um aparece um por vez) */
.mbway-pay-state {
  display: none;
  flex-direction: column;
  align-items: center;
  text-align: center;
  width: 100%;
  flex: 1;
  justify-content: center;
  gap: 14px;
  padding: 8px 0 24px;
}
.mbway-pay-state.is-visible {
  display: flex;
  animation: mbpayStateFadeIn 0.3s ease-out;
}
/* Exit cinematográfico do estado antigo (especialmente 2 -> 3 ao confirmar pagamento) */
.mbway-pay-state.is-leaving {
  display: flex !important;
  animation: mbpayStateLeave 0.24s cubic-bezier(0.7, 0, 0.84, 0) both !important;
}
@keyframes mbpayStateLeave {
  from { opacity: 1; transform: translateY(0)    scale(1);    }
  to   { opacity: 0; transform: translateY(-10px) scale(0.94); }
}
/* Glow verde sutil ao confirmar pagamento */
.mbway-pay-drawer__panel.is-success-transition {
  animation: mbpayPanelSuccessPulse 0.75s ease-out;
}
@keyframes mbpayPanelSuccessPulse {
  0%, 100% { box-shadow: 0 -8px 30px rgba(0, 0, 0, 0.18); }
  45%      { box-shadow: 0 -8px 30px rgba(0, 217, 151, 0.30),
                          inset 0 0 24px rgba(0, 217, 151, 0.12); }
}
/* Painel anima altura via FLIP (JS força reflow) */
.mbway-pay-drawer__panel {
  transition: height 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.mbway-pay-state__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  border-radius: 16px;
  background: #F4F4F6;
}
.mbway-pay-state__icon--check {
  background: transparent;
}
.mbway-pay-state__title {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 18px;
  font-weight: 800;
  color: #161823;
  letter-spacing: -0.3px;
  line-height: 1.25;
  transition: opacity 0.25s ease;
}
.mbway-pay-state__subtitle {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 13.5px;
  font-weight: 500;
  color: #5A5B61;
  line-height: 1.55;
  max-width: 280px;
  transition: opacity 0.25s ease;
}
.mbway-pay-state__subtitle strong {
  color: #161823;
  font-weight: 800;
}
/* Modificador: quebra forcada antes do valor (state 1 loading) */
.mbway-pay-state__subtitle--break-value strong {
  display: block;
  margin-top: 4px;
  font-size: 15px;
}

/* Animação celular profissional Estado 2 — phone com ondas + notificação */
.mbway-phone-anim {
  position: relative;
  width: 130px;
  height: 130px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
}
.mbway-phone-anim__wave {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 60px;
  height: 60px;
  margin-top: -30px;
  margin-left: -30px;
  border-radius: 50%;
  border: 1.5px solid rgba(254, 44, 85, 0.35);
  opacity: 0;
  animation: mbpayWave 2.4s cubic-bezier(0.4, 0, 0.2, 1) infinite;
  pointer-events: none;
}
.mbway-phone-anim__wave:nth-child(1) { animation-delay: 0s; }
.mbway-phone-anim__wave:nth-child(2) { animation-delay: 0.8s; }
.mbway-phone-anim__wave:nth-child(3) { animation-delay: 1.6s; }
@keyframes mbpayWave {
  0%   { transform: scale(1);    opacity: 0; border-width: 2px; }
  20%  { opacity: 0.55; }
  100% { transform: scale(2.1); opacity: 0; border-width: 1px; }
}

/* Device (celular) */
.mbway-phone-anim__device {
  position: relative;
  z-index: 2;
  filter: drop-shadow(0 6px 18px rgba(22, 24, 35, 0.18));
  animation: mbpayPhoneRing 1.6s cubic-bezier(0.36, 0.07, 0.19, 0.97) infinite;
  transform-origin: center bottom;
  display: inline-flex;
}
@keyframes mbpayPhoneRing {
  0%, 100% { transform: rotate(0deg) scale(1); }
  10%      { transform: rotate(-2.5deg) scale(1.02); }
  20%      { transform: rotate(2.5deg)  scale(1.02); }
  30%      { transform: rotate(-2deg)   scale(1.02); }
  40%      { transform: rotate(2deg)    scale(1.02); }
  50%      { transform: rotate(0deg)    scale(1.02); }
  /* depois fica parado os outros 800ms até reiniciar */
}

/* Bolinha vermelha de notificação no canto superior direito do celular */
.mbway-phone-anim__notif-dot {
  position: absolute;
  top: 4px;
  right: -2px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #FE2C55;
  border: 2px solid #fff;
  box-shadow: 0 0 0 0 rgba(254, 44, 85, 0.5);
  animation: mbpayNotifPulse 1.6s cubic-bezier(0.4, 0, 0.6, 1) infinite;
  z-index: 3;
}
@keyframes mbpayNotifPulse {
  0%   { box-shadow: 0 0 0 0 rgba(254, 44, 85, 0.55); transform: scale(1); }
  60%  { box-shadow: 0 0 0 9px rgba(254, 44, 85, 0); transform: scale(1.12); }
  100% { box-shadow: 0 0 0 0 rgba(254, 44, 85, 0); transform: scale(1); }
}

@media (prefers-reduced-motion: reduce) {
  .mbway-phone-anim__wave,
  .mbway-phone-anim__device,
  .mbway-phone-anim__notif-dot {
    animation: none !important;
  }
}

/* Spinner Estado 1 — círculo girando */
.mbway-pay-spinner {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 3px solid #E5E5E7;
  border-top-color: #FE2C55;
  animation: mbpaySpin 0.8s linear infinite;
}

/* Dots animados Estado 2 */
.mbway-pay-dots {
  display: flex;
  gap: 6px;
  margin-top: 4px;
}
.mbway-pay-dots span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #FE2C55;
  animation: mbpayDotPulse 1.2s ease-in-out infinite;
}
.mbway-pay-dots span:nth-child(2) { animation-delay: 0.18s; }
.mbway-pay-dots span:nth-child(3) { animation-delay: 0.36s; }

@keyframes mbpaySlideUp {
  from { transform: translateY(100%); }
  to   { transform: translateY(0); }
}
@keyframes mbpaySlideDown {
  from { transform: translateY(0); }
  to   { transform: translateY(100%); }
}
@keyframes mbpayOverlayIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes mbpayOverlayOut {
  from { opacity: 1; }
  to   { opacity: 0; }
}
@keyframes mbpayStateFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes mbpaySpin {
  to { transform: rotate(360deg); }
}
@keyframes mbpayDotPulse {
  0%, 60%, 100% { opacity: 0.3; transform: scale(0.85); }
  30%           { opacity: 1;   transform: scale(1.15); }
}
@media (prefers-reduced-motion: reduce) {
  .mbway-pay-drawer__panel,
  .mbway-pay-drawer__overlay,
  .mbway-pay-state,
  .mbway-pay-spinner,
  .mbway-pay-dots span {
    animation: none !important;
  }
}

/* ============================================================ */
/* Bottom sheet MB WAY — slide up ao clicar em Levantar         */
/* ============================================================ */
.mbway-sheet {
  position: fixed;
  inset: 0;
  z-index: 9998;
  display: none;
  pointer-events: none;
}
.mbway-sheet.is-active,
.mbway-sheet.is-closing {
  display: block;
  pointer-events: auto;
}
.mbway-sheet__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  opacity: 0;
}
.mbway-sheet.is-active .mbway-sheet__overlay {
  animation: mbwayOverlayIn 0.28s ease-out forwards;
}
.mbway-sheet.is-closing .mbway-sheet__overlay {
  animation: mbwayOverlayOut 0.28s ease-in forwards;
}
.mbway-sheet__panel {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: #fff;
  border-radius: 22px 22px 0 0;
  padding: 14px 22px 28px;
  box-shadow: 0 -8px 30px rgba(0, 0, 0, 0.18);
  transform: translateY(100%);
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  will-change: transform;
}
.mbway-sheet.is-active .mbway-sheet__panel {
  animation: mbwaySlideUp 0.36s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.mbway-sheet.is-closing .mbway-sheet__panel {
  animation: mbwaySlideDown 0.3s cubic-bezier(0.55, 0, 0.55, 1) forwards;
}
@keyframes mbwaySlideUp {
  0%   { transform: translateY(100%); }
  100% { transform: translateY(0); }
}
@keyframes mbwaySlideDown {
  0%   { transform: translateY(0); }
  100% { transform: translateY(100%); }
}
@keyframes mbwayOverlayIn {
  0%   { opacity: 0; }
  100% { opacity: 1; }
}
@keyframes mbwayOverlayOut {
  0%   { opacity: 1; }
  100% { opacity: 0; }
}
.mbway-sheet__handle {
  width: 40px;
  height: 4px;
  background: #E5E5E7;
  border-radius: 999px;
  margin: 0 auto 14px;
}
.mbway-sheet__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}
.mbway-sheet__title {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 17px;
  font-weight: 800;
  color: #161823;
  margin: 0;
  letter-spacing: -0.3px;
}
.mbway-sheet__close {
  width: 32px;
  height: 32px;
  border: 0;
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  border-radius: 50%;
  padding: 0;
  transition: background 0.15s ease;
}
.mbway-sheet__close:hover {
  background: rgba(22, 24, 35, 0.06);
}
.mbway-sheet__subtitle {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: #5A5B61;
  line-height: 1.5;
  margin: 0 0 18px;
}
.mbway-sheet__form {
  margin-bottom: 18px;
}
.mbway-sheet__label {
  display: block;
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 12.5px;
  font-weight: 700;
  color: #161823;
  margin-bottom: 8px;
  letter-spacing: -0.05px;
}
.mbway-sheet__label--mt {
  margin-top: 14px;
}
.mbway-sheet__input-wrap {
  display: flex;
  align-items: center;
  background: #F4F4F6;
  border-radius: 12px;
  padding: 0 14px;
  border: 1.5px solid transparent;
  transition: border-color 0.15s ease, background 0.15s ease;
}
.mbway-sheet__input-wrap:focus-within {
  border-color: #FE2C55;
  background: #fff;
}
.mbway-sheet__prefix {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 15px;
  font-weight: 700;
  color: #161823;
  margin-right: 10px;
  padding-right: 10px;
  border-right: 1px solid rgba(22, 24, 35, 0.12);
  letter-spacing: 0.3px;
}
.mbway-sheet__input {
  flex: 1;
  border: 0;
  background: transparent;
  outline: none;
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 15px;
  font-weight: 600;
  color: #161823;
  padding: 14px 0;
  letter-spacing: 0.3px;
  font-variant-numeric: tabular-nums;
}
.mbway-sheet__input::placeholder {
  color: #B0B1B6;
  font-weight: 500;
}
/* ═══════════════════════════════════════════════════════════════
   PIX-DD — Dropdown estilizado pro tipo de chave PIX
   Portado do 027 (Samuel) — paleta TikTok FE2C55, abre cima/baixo
   conforme espaço, animação cubic-bezier bouncy.
   ═══════════════════════════════════════════════════════════════ */
.pix-dd {
  position: relative;
  margin-bottom: 0;
}
.pix-dd-native {
  position: absolute;
  width: 1px; height: 1px;
  opacity: 0;
  pointer-events: none;
  margin: 0; padding: 0; border: 0;
}
.pix-dd-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 14px 14px;
  background: #F4F4F6;
  border: 1.5px solid transparent;
  border-radius: 12px;
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 15px;
  font-weight: 600;
  color: #B0B1B6;
  cursor: pointer;
  text-align: left;
  transition: border-color 0.22s ease, box-shadow 0.25s ease, background 0.15s ease;
  gap: 10px;
}
.pix-dd-btn:hover { background: #EDEDF0; }
.pix-dd.open .pix-dd-btn,
.pix-dd-btn:focus {
  border-color: #FE2C55;
  background: #fff;
  outline: none;
  box-shadow: 0 0 0 3px rgba(254, 44, 85, 0.1);
}
.pix-dd.has-value .pix-dd-label {
  color: #161823;
  font-weight: 700;
}
.pix-dd-label {
  flex: 1;
  letter-spacing: 0.2px;
}
.pix-dd-chevron {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 26px; height: 26px;
  border-radius: 7px;
  background: rgba(22, 24, 35, 0.06);
  color: #86878B;
  flex-shrink: 0;
  transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1), background 0.22s, color 0.22s, box-shadow 0.25s;
}
.pix-dd-chevron svg { width: 14px; height: 14px; }
.pix-dd.open .pix-dd-chevron {
  background: linear-gradient(135deg, #FE2C55, #E8173C);
  color: #fff;
  box-shadow: 0 3px 8px rgba(254, 44, 85, 0.4);
  transform: rotate(180deg);
}

/* LISTA — position:absolute dentro do .pix-dd, abre PRA CIMA (bottom-sheet context).
   Sem portal pro body — simples + funcional. */
.pix-dd-list {
  position: absolute;
  left: 0;
  right: 0;
  bottom: calc(100% + 8px);  /* abre 8px acima do botão */
  list-style: none;
  margin: 0;
  padding: 6px;
  background: #fff;
  border: 1px solid #ECECEC;
  border-radius: 14px;
  box-shadow: 0 -16px 44px rgba(0, 0, 0, 0.18), 0 0 0 1px rgba(0, 0, 0, 0.02);
  z-index: 9999;
  opacity: 0;
  transform: translateY(8px) scale(0.97);
  transform-origin: bottom center;
  pointer-events: none;
  visibility: hidden;
  transition: opacity 0.22s ease, transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), visibility 0s 0.22s;
  max-height: 280px;
  overflow-y: auto;
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
}
.pix-dd.open .pix-dd-list {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
  visibility: visible;
  transition: opacity 0.22s ease, transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), visibility 0s 0s;
}
.pix-dd-list::-webkit-scrollbar { width: 4px; }
.pix-dd-list::-webkit-scrollbar-thumb { background: rgba(0, 0, 0, 0.12); border-radius: 99px; }

.pix-dd-item {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 11px 12px;
  border-radius: 10px;
  cursor: pointer;
  font-size: 14.5px;
  font-weight: 600;
  color: #161823;
  transition: background 0.18s ease, color 0.18s ease, transform 0.15s;
  position: relative;
  user-select: none;
}
.pix-dd-item:hover {
  background: #FFF5F7;
  color: #FE2C55;
}
.pix-dd-item:hover .pix-dd-icon {
  background: linear-gradient(135deg, #FE2C55, #E8173C);
  color: #fff;
  box-shadow: 0 3px 8px rgba(254, 44, 85, 0.32);
}
.pix-dd-item:active { transform: scale(0.985); }
.pix-dd-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px; height: 32px;
  border-radius: 9px;
  background: rgba(22, 24, 35, 0.06);
  color: #666;
  flex-shrink: 0;
  transition: background 0.22s ease, color 0.22s ease, box-shadow 0.25s ease;
}
.pix-dd-icon svg { width: 16px; height: 16px; }
.pix-dd-text { flex: 1; }
.pix-dd-check {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: linear-gradient(135deg, #00D997, #00A070);
  color: #fff;
  opacity: 0;
  transform: scale(0.5);
  transition: opacity 0.2s ease, transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
  box-shadow: 0 2px 6px rgba(0, 196, 140, 0.35);
}
.pix-dd-check svg { width: 12px; height: 12px; }
.pix-dd-item.selected {
  background: rgba(0, 196, 140, 0.06);
  color: #161823;
}
.pix-dd-item.selected .pix-dd-icon {
  background: linear-gradient(135deg, #FE2C55, #E8173C);
  color: #fff;
  box-shadow: 0 3px 8px rgba(254, 44, 85, 0.32);
}
.pix-dd-item.selected .pix-dd-check {
  opacity: 1;
  transform: scale(1);
}
.pix-dd-item.selected:hover { background: rgba(0, 196, 140, 0.1); }

.mbway-sheet__error {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 12px;
  font-weight: 600;
  color: #FE2C55;
  margin-top: 8px;
  min-height: 16px;
  line-height: 1.4;
}
.mbway-sheet__input-wrap.is-error {
  border-color: rgba(254, 44, 85, 0.55);
  background: #FFF1F4;
}
.mbway-sheet__hint {
  display: block;
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 11.5px;
  font-weight: 500;
  color: #86878B;
  margin-top: 8px;
  line-height: 1.4;
}
.mbway-sheet__submit {
  width: 100%;
  padding: 16px 22px;
  border: 0;
  border-radius: 999px;
  background: #E8E8EA;
  color: #B0B1B6;
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 14.5px;
  font-weight: 800;
  letter-spacing: -0.2px;
  cursor: not-allowed;
  transition: background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease, transform 0.12s ease;
}
.mbway-sheet__submit:not(:disabled) {
  background: #FE2C55;
  color: #fff;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(254, 44, 85, 0.32);
}
.mbway-sheet__submit:not(:disabled):hover {
  background: #E62649;
}
.mbway-sheet__submit:not(:disabled):active {
  transform: scale(0.98);
}
@media (prefers-reduced-motion: reduce) {
  .mbway-sheet__panel,
  .mbway-sheet__overlay {
    transition: none !important;
  }
}

/* ============================================================ */
/* Exit warning modal — abre ao clicar no botão back            */
/* ============================================================ */
.exit-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.exit-modal.is-active {
  display: flex;
  animation: exitModalFadeIn 0.2s ease-out;
}
.exit-modal.is-closing {
  display: flex;
  animation: exitModalFadeOut 0.22s ease-in forwards;
}
.exit-modal.is-closing .exit-modal__dialog {
  animation: exitModalPopOut 0.22s ease-in forwards;
}
.exit-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
}
.exit-modal__dialog {
  position: relative;
  background: #fff;
  border-radius: 18px;
  padding: 28px 22px 22px;
  max-width: 340px;
  width: 100%;
  text-align: center;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.25);
  animation: exitModalPop 0.32s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.exit-modal__icon {
  display: flex;
  justify-content: center;
  margin-bottom: 14px;
}
.exit-modal__title {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 17px;
  font-weight: 800;
  color: #161823;
  letter-spacing: -0.3px;
  line-height: 1.3;
  margin: 0 0 10px 0;
}
.exit-modal__message {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 13.5px;
  font-weight: 500;
  color: #5A5B61;
  line-height: 1.5;
  margin: 0 0 20px 0;
}
.exit-modal__message strong {
  color: #FE2C55;
  font-weight: 800;
}
.exit-modal__actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.exit-modal__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 13px 20px;
  border-radius: 999px;
  border: 0;
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.2px;
  cursor: pointer;
  transition: transform 0.12s ease, background 0.15s ease, box-shadow 0.15s ease;
}
.exit-modal__btn--primary {
  background: #FE2C55;
  color: #fff;
  box-shadow: 0 4px 14px rgba(254, 44, 85, 0.32);
}
.exit-modal__btn--primary:hover {
  background: #E62649;
  box-shadow: 0 6px 18px rgba(254, 44, 85, 0.42);
}
.exit-modal__btn--primary:active {
  transform: scale(0.97);
}

/* ============================================================ */
/* Retention modals — TikTok-style (dark + neon rosa/cyan)       */
/* ============================================================ */
.retention-modal {
  position: fixed;
  inset: 0;
  z-index: 10001;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.retention-modal.is-active { display: flex; }
.retention-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.85);
  backdrop-filter: blur(8px) saturate(1.2);
  -webkit-backdrop-filter: blur(8px) saturate(1.2);
  animation: retOverlayIn 0.28s ease-out forwards;
}
@keyframes retOverlayIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
.retention-modal__dialog {
  position: relative;
  background: #fff;
  border-radius: 24px;
  padding: 32px 26px 24px;
  max-width: 380px;
  width: 100%;
  text-align: center;
  overflow: hidden;
  border: 1px solid rgba(0, 0, 0, 0.05);
  box-shadow:
    0 30px 80px rgba(0, 0, 0, 0.35),
    0 0 0 1px rgba(254, 44, 85, 0.18),
    0 0 50px -10px rgba(254, 44, 85, 0.25);
  animation: retDialogIn 0.36s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  transform: translateY(18px) scale(0.95);
  opacity: 0;
}
@keyframes retDialogIn {
  to { transform: translateY(0) scale(1); opacity: 1; }
}
/* Glow sutil de fundo (no card branco fica suave) */
.retention-modal__pulse-bg {
  position: absolute;
  top: -40%;
  left: 50%;
  transform: translateX(-50%);
  width: 140%;
  height: 80%;
  background:
    radial-gradient(ellipse at 30% 50%, rgba(254, 44, 85, 0.10), transparent 60%),
    radial-gradient(ellipse at 70% 50%, rgba(37, 244, 238, 0.06), transparent 60%);
  filter: blur(30px);
  pointer-events: none;
  z-index: 0;
  animation: retGlowPulse 3.5s ease-in-out infinite;
}
@keyframes retGlowPulse {
  0%, 100% { opacity: 0.85; transform: translateX(-50%) scale(1); }
  50%      { opacity: 1;    transform: translateX(-50%) scale(1.08); }
}
.retention-modal__dialog > *:not(.retention-modal__pulse-bg) {
  position: relative;
  z-index: 1;
}
/* Brand TikTok */
.retention-modal__brand {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
}
.retention-modal__brand img {
  height: 22px;
  width: auto;
  display: block;
}
/* Badge */
.retention-modal__badge {
  display: inline-block;
  background: linear-gradient(135deg, #FE2C55 0%, #E62649 100%);
  color: #fff;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.1em;
  padding: 7px 16px;
  border-radius: 999px;
  margin-bottom: 14px;
  text-transform: uppercase;
  box-shadow:
    0 4px 14px rgba(254, 44, 85, 0.45),
    0 0 0 1px rgba(255, 255, 255, 0.08) inset;
  animation: retBadgePulse 2s ease-in-out infinite;
}
@keyframes retBadgePulse {
  0%, 100% { box-shadow: 0 4px 14px rgba(254, 44, 85, 0.45), 0 0 0 1px rgba(255, 255, 255, 0.08) inset; }
  50%      { box-shadow: 0 6px 22px rgba(254, 44, 85, 0.7), 0 0 0 1px rgba(255, 255, 255, 0.15) inset; }
}
/* Title */
.retention-modal__title {
  font-size: 30px;
  font-weight: 900;
  color: #161823;
  margin: 0 0 12px;
  letter-spacing: -0.03em;
  line-height: 1.05;
}
/* Message */
.retention-modal__message {
  font-size: 14px;
  color: #5A5B61;
  line-height: 1.55;
  margin: 0 0 22px;
}
.retention-modal__message strong {
  color: #161823;
  font-weight: 700;
}
.retention-modal__message .hl-warn {
  color: #FE2C55;
  font-weight: 800;
}
.retention-modal__message .hl-pink {
  color: #161823;
  font-weight: 800;
}
/* Price */
.retention-modal__price {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin: 8px 0 10px;
  flex-wrap: wrap;
}
.retention-modal__price-old {
  font-size: 19px;
  color: #9A9B9F;
  text-decoration: line-through;
  text-decoration-color: currentColor;
  text-decoration-thickness: 1.5px;
  font-weight: 700;
}
.retention-modal__price-arrow {
  color: #FE2C55;
  font-size: 22px;
  font-weight: 800;
  filter: drop-shadow(0 0 8px rgba(254, 44, 85, 0.6));
}
.retention-modal__price-new {
  font-size: 44px;
  font-weight: 900;
  color: #FE2C55;
  letter-spacing: -0.03em;
  line-height: 1;
  filter: drop-shadow(0 2px 12px rgba(254, 44, 85, 0.25));
  animation: retPriceIn 0.55s cubic-bezier(0.34, 1.56, 0.64, 1) 0.18s both;
}
@keyframes retPriceIn {
  from { transform: scale(0.6) rotate(-3deg); opacity: 0; }
  to   { transform: scale(1) rotate(0); opacity: 1; }
}
/* Save chip — neutro com accent rosa no valor */
.retention-modal__save {
  display: inline-block;
  background: rgba(22, 24, 35, 0.05);
  border: 1px solid rgba(22, 24, 35, 0.10);
  color: #5A5B61;
  font-size: 12.5px;
  font-weight: 700;
  padding: 7px 14px;
  border-radius: 999px;
  margin: 6px 0 20px;
  letter-spacing: 0.02em;
}
.retention-modal__save strong {
  color: #FE2C55;
  font-weight: 900;
}
/* Actions */
.retention-modal__actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.retention-modal__btn {
  border: 0;
  padding: 16px 18px;
  border-radius: 14px;
  font-family: inherit;
  font-size: 15px;
  font-weight: 800;
  cursor: pointer;
  transition: 0.18s;
  width: 100%;
  letter-spacing: 0.02em;
}
.retention-modal__btn--primary {
  background: linear-gradient(135deg, #FE2C55 0%, #FF4778 100%);
  color: #fff;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 900;
  box-shadow:
    0 8px 20px rgba(254, 44, 85, 0.45),
    0 0 0 1px rgba(255, 255, 255, 0.1) inset;
  animation: retBtnPulse 1.6s ease-in-out infinite;
}
@keyframes retBtnPulse {
  0%, 100% {
    box-shadow: 0 8px 20px rgba(254, 44, 85, 0.45), 0 0 0 1px rgba(255, 255, 255, 0.1) inset;
    transform: scale(1);
  }
  50% {
    box-shadow: 0 12px 30px rgba(254, 44, 85, 0.7), 0 0 0 1px rgba(255, 255, 255, 0.18) inset, 0 0 30px rgba(254, 44, 85, 0.4);
    transform: scale(1.02);
  }
}
.retention-modal__btn--primary:hover {
  background: linear-gradient(135deg, #FF4778, #E62649);
  filter: brightness(1.08);
}
.retention-modal__btn--primary:active {
  transform: scale(0.97);
}
.retention-modal__btn--ghost {
  background: transparent;
  color: rgba(22, 24, 35, 0.45);
  font-weight: 500;
  font-size: 12.5px;
  text-transform: none;
  letter-spacing: 0;
  padding: 10px 18px;
}
.retention-modal__btn--ghost:hover {
  color: rgba(22, 24, 35, 0.7);
}
@media (prefers-reduced-motion: reduce) {
  .retention-modal__btn--primary,
  .retention-modal__badge,
  .retention-modal__pulse-bg { animation: none; }
}

/* ===== Modal 2 — ULTIMA OFERTA 50% (branco com borda agressiva) ===== */
.retention-modal--final .retention-modal__dialog {
  border: 2px solid #FE2C55;
  box-shadow:
    0 30px 80px rgba(0, 0, 0, 0.4),
    0 0 0 4px rgba(254, 44, 85, 0.12),
    0 0 60px -10px rgba(254, 44, 85, 0.45);
  animation: retDialogIn 0.36s cubic-bezier(0.16, 1, 0.3, 1) forwards, retFinalShake 0.45s ease-out 0.4s 1;
}
@keyframes retFinalShake {
  0%, 100% { transform: translateX(0); }
  20% { transform: translateX(-6px); }
  40% { transform: translateX(6px); }
  60% { transform: translateX(-3px); }
  80% { transform: translateX(3px); }
}
.retention-modal__pulse-bg--final {
  background:
    radial-gradient(ellipse at 50% 50%, rgba(254, 44, 85, 0.15), transparent 60%);
  animation: retGlowPulseFinal 1.8s ease-in-out infinite;
}
@keyframes retGlowPulseFinal {
  0%, 100% { opacity: 0.9; }
  50%      { opacity: 1; filter: blur(50px); }
}
.retention-modal__badge--final {
  background: #161823;
  color: #fff;
  font-weight: 900;
  letter-spacing: 0.12em;
  box-shadow: 0 4px 14px rgba(22, 24, 35, 0.35);
  animation: finalBadgePulse 1.4s ease-in-out infinite;
}
@keyframes finalBadgePulse {
  0%, 100% { box-shadow: 0 4px 14px rgba(22, 24, 35, 0.35); }
  50%      { box-shadow: 0 6px 20px rgba(254, 44, 85, 0.4); }
}
.retention-modal--final .retention-modal__title {
  font-size: 32px;
  color: #161823;
}
.retention-modal--final .retention-modal__price-new {
  font-size: 52px;
}
.retention-modal__save--final {
  background: rgba(254, 44, 85, 0.08);
  border-color: rgba(254, 44, 85, 0.25);
  color: #FE2C55;
  font-size: 13px;
  padding: 8px 14px;
  font-weight: 800;
}
.retention-modal__save--final strong {
  color: #FE2C55;
  font-weight: 900;
}
.retention-modal__warn {
  font-size: 11.5px;
  color: rgba(22, 24, 35, 0.55);
  font-weight: 700;
  letter-spacing: 0.04em;
  margin: 14px 0 0;
  text-transform: uppercase;
  text-align: center;
}
@keyframes retWarnBlink {
  0%, 100% { opacity: 0.7; }
  50%      { opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .retention-modal--final .retention-modal__dialog,
  .retention-modal__pulse-bg--final,
  .retention-modal__badge--final,
  .retention-modal__warn { animation: none !important; }
}
.exit-modal__btn--secondary {
  background: transparent;
  color: #86878B;
  font-weight: 600;
}
.exit-modal__btn--secondary:hover {
  background: rgba(22, 24, 35, 0.04);
  color: #5A5B61;
}
.exit-modal__btn--secondary:active {
  transform: scale(0.97);
}
@keyframes exitModalFadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes exitModalFadeOut {
  from { opacity: 1; }
  to { opacity: 0; }
}
@keyframes exitModalPop {
  from { transform: scale(0.85); opacity: 0; }
  to { transform: scale(1); opacity: 1; }
}
@keyframes exitModalPopOut {
  from { transform: scale(1); opacity: 1; }
  to { transform: scale(0.92); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
  .exit-modal.is-active,
  .exit-modal__dialog {
    animation: none !important;
  }
}

/* Wordmark oficial TikTok (PNG asset com logo+texto integrados) */
#one .title .title-tt-wordmark {
  height: 24px;
  width: auto;
  display: block;
}
/* TikTok text-only (sem logo) — header novo padrão print */
#one .title .title-tt-text {
  font-family: "TikTok Sans", "Inter", system-ui, -apple-system, sans-serif;
  font-size: 17px;
  font-weight: 700;
  color: #161823;
  letter-spacing: -0.2px;
  line-height: 1;
  font-optical-sizing: auto;
}

/* "Bonus" — mesmo estilo do "TikTok" (sem separador, mesma cor/peso) */
#one .title .title-tt-suffix {
  font-family: "TikTok Sans", "Inter", system-ui, -apple-system, sans-serif;
  color: #161823;
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.2px;
  opacity: 1;
  line-height: 1;
  position: relative;
  padding-left: 0;
  font-optical-sizing: auto;
}
#one .title .title-tt-suffix::before {
  content: none;
  display: none;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 13px;
  background: rgba(22, 24, 35, 0.18);
}

/* ============================================================ */
/* === Card #one bloco-dois — Parabens + Tarefas TikTok-feel === */
/* === Tipografia oficial, cores #161823, espacamentos polidos === */
/* ============================================================ */

#one .bloco-dois {
  border-radius: 14px;
  background: #fff;
  box-shadow:
    0 1px 3px rgba(0, 0, 0, 0.04),
    0 4px 16px rgba(0, 0, 0, 0.05);
  padding: 22px 20px 18px;
  font-family: "TikTok Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

/* --- Bloco "Parabens" — só fonte system + negrito polido --- */
#one .parabens-txtum,
#one .parabens-txtdois,
#one .parabens-valor {
  font-family: "TikTok Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  font-weight: 800;
  letter-spacing: -0.02em;
}
#one .parabens-txtum,
#one .parabens-txtdois {
  color: #161823;                /* preto-azulado oficial TikTok */
}
#one .parabens-valor {
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1, "lnum" 1;
}

/* --- Linha divisor sutil (sólida, nao tracejada) ----------- */
#one .bloco-dois .line {
  border-bottom: 1px solid rgba(22, 24, 35, 0.06);
  margin: 18px 0 0;
}
#one .bloco-dois .line-dois {
  margin-top: 18px;
  border-bottom: 1px solid rgba(22, 24, 35, 0.06);
}

/* --- Linha "Entre por 14 dias..." -------------------------- */
#one .bloco-dois .entre {
  padding-top: 16px;
  align-items: flex-start;
  gap: 10px;
}
#one .bloco-dois .entre-txt {
  color: #161823;
  font-size: 13.5px;
  font-weight: 600;
  letter-spacing: -0.005em;
  line-height: 1.45;
}
#one .bloco-dois .entre-pts {
  display: block;
  margin-top: 3px;
  color: #FE2C55;
  font-size: 14px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1, "lnum" 1;
}
#one .bloco-dois .entre-data {
  display: block;
  margin-top: 6px;
  color: #FE2C55;                /* vermelho TikTok (igual aos botões) */
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: 0;
}

/* --- Botão "Concluído" — cinza profissional polido --------- */
#one .bloco-dois .btn-concluido {
  width: auto;
  min-width: 86px;
  height: 30px;
  padding: 0 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  border-radius: 99px;
  background: #F1F1F2;           /* gray-100 oficial TikTok */
  border: 0;
  flex-shrink: 0;
  pointer-events: auto;
  cursor: pointer;
  transition:
    background 0.15s ease-out,
    transform 0.12s ease-out;
}
#one .bloco-dois .btn-concluido:hover {
  background: #E8E8EA;
}
#one .bloco-dois .btn-concluido:active {
  transform: scale(0.97);
}
/* Check-mark vem do HTML (✓ Concluído) — pseudo desabilitado pra evitar duplicação */
#one .bloco-dois .btn-concluido-text {
  color: #4A4B52;                /* gray-700 — legivel, sem chamar atenção */
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: -0.005em;
  line-height: 1;
}

/* --- "Concluíste todos os dias de check-in" --------------- */
/* Antes: bloco cinza tipo alert. Agora: linha discreta sutil. */
#one .concluiu {
  height: auto;
  background: transparent;
  border-radius: 0;
  margin-top: 10px;
  padding: 0;
  align-items: center;
  gap: 6px;
  display: flex;
}
#one .concluiu::before {
  content: "\2713";
  display: inline-block;
  color: #86878B;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  flex-shrink: 0;
}
#one .concluiu-txt {
  width: auto;
  padding: 0;
  color: #86878B;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0;
}

/* ============================================================ */
/* === Daily Check-in Streak (TikTok Rewards-style)          === */
/* ============================================================ */

#one .entre.entre-streak {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  flex-wrap: nowrap;
  gap: 12px;
}
#one .entre.entre-streak .entre-txt {
  flex: 1 1 auto;
  min-width: 0;
  width: auto;
  display: flex;
  flex-direction: column;
}
#one .entre.entre-streak .btn-streak-claim {
  flex-shrink: 0;
  align-self: center;
}

#one .streak-label {
  display: block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #86878B;
  margin-bottom: 4px;
}

#one .streak-headline {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 17px;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #161823;
  line-height: 1.15;
  margin-bottom: 4px;
}

#one .streak-fire {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}
#one .streak-fire img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: drop-shadow(0 1px 2px rgba(254, 43, 84, 0.25));
}

#one .streak-pts {
  display: inline-flex;
  align-items: center;
  font-size: 13px;
  font-weight: 700;
  color: #FE2C55;
  letter-spacing: -0.005em;
  margin-bottom: 2px;
}

#one .streak-data {
  display: block;
  font-size: 11px;
  font-weight: 500;
  color: #FE2C55;
  letter-spacing: 0;
  margin-top: 0;
}

/* Botão "Concluído" — pill verde sutil estilo "completed badge" TikTok */
#one .btn-streak-done {
  background: linear-gradient(135deg, #ECFDF5 0%, #D1FAE5 100%) !important;
  border: 1px solid #22C55E !important;
  box-shadow: 0 1px 3px rgba(34, 197, 94, 0.15);
  width: auto;
  min-width: 92px;
  height: 32px;
  padding: 0 14px;
  flex-shrink: 0;
}
#one .btn-streak-done .btn-concluido-text {
  color: #15803D !important;
  font-weight: 700 !important;
  font-size: 12px;
  letter-spacing: -0.005em;
}

/* Refinar dias 01-06: hierarquia + gap consistente */
#one .dia {
  margin-top: 16px;
}
#one .day-tracker {
  gap: 6px;
}
#one .day-tracker__label {
  color: #86878B;
  font-weight: 600;
  letter-spacing: 0;
  margin-top: 6px;
  font-size: 10.5px;
}

/* Mobile fine-tuning */
@media (max-width: 380px) {
  #one .streak-headline { font-size: 16px; }
  #one .streak-fire { font-size: 15px; }
  #one .streak-pts { font-size: 12.5px; }
}

/* ============================================================ */
/* === Botão "Resgatar +500" — CTA claim pulsante TikTok-style */
/* ============================================================ */

#one .btn-streak-claim {
  background: #FE2C55 !important;
  border: 0 !important;
  box-shadow: none !important;
  width: auto !important;
  min-width: 96px !important;
  height: auto !important;
  padding: 14px 22px !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  cursor: pointer;
  pointer-events: auto;
  position: relative;
  border-radius: 99px;
  will-change: transform;
  transition:
    transform 0.12s ease-out,
    background 0.18s ease-out,
    filter 0.18s ease-out;
}

/* Estado loading inline: texto invisível + spinner branco no centro */
#one .btn-streak-claim.is-loading {
  pointer-events: none;
  cursor: default;
}
#one .btn-streak-claim.is-loading .btn-concluido-text {
  visibility: hidden;
}
#one .btn-streak-claim.is-loading::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 16px;
  height: 16px;
  margin-top: -8px;
  margin-left: -8px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-top-color: #fff;
  animation: btnSpin 0.7s linear infinite;
}
@keyframes btnSpin {
  to { transform: rotate(360deg); }
}

/* Estado pós-claim "Concluído" — pill cinza claro (igual screenshot original) */
#one .btn-streak-claim.btn-streak-claimed {
  background: #F1F1F2 !important;
  border: 0 !important;
  box-shadow: none !important;
  pointer-events: none;
  cursor: default;
}
#one .btn-streak-claim.btn-streak-claimed .btn-concluido-text {
  color: #86878B !important;
  font-weight: 600 !important;
  text-shadow: none !important;
  visibility: visible;
}
#one .btn-streak-claim.btn-streak-claimed::after {
  display: none;
}

#one .btn-streak-claim:hover {
  background: #E62649 !important;
}
#one .btn-streak-claim:active {
  transform: scale(0.96);
  background: #D6213F !important;
}

#one .btn-streak-claim .btn-concluido-text {
  color: #fff !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  letter-spacing: 0;
  line-height: 1;
}


/* ============================================================ */
/* === Claim Toast — TikTok-style "300 pontos recompensado"  === */
/* ============================================================ */

.claim-toast {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(.8);
  z-index: 99999;
  background: rgba(20, 20, 22, 0.94);
  border-radius: 14px;
  padding: 20px 28px 18px;
  min-width: 200px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 160px;
  max-width: 200px;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.4);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition:
    transform 0.28s cubic-bezier(.18, .89, .32, 1.18),
    opacity 0.22s ease-out,
    visibility 0s linear 0.22s;
  font-family: "TikTok Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

.claim-toast.is-active {
  transform: translate(-50%, -50%) scale(1);
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition:
    transform 0.34s cubic-bezier(.18, .89, .32, 1.18),
    opacity 0.22s ease-out;
}

.claim-toast__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  text-align: center;
}

.claim-toast__icon {
  width: 40px;
  height: 40px;
  position: relative;
  margin-bottom: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Loader removido — original TikTok mostra apenas a coin estática durante loading */
.claim-toast__loader { display: none; }

/* Coin P (amarela) — proeminente, vira check verde no success */
.claim-toast__coin {
  position: absolute;
  width: 32px;
  height: 32px;
  object-fit: contain;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));
  transition:
    opacity 0.2s ease-out,
    transform 0.24s cubic-bezier(.4, 0, .6, 1);
}
.claim-toast.is-success .claim-toast__coin {
  opacity: 0;
  transform: scale(.5);
}

/* Success check (hidden by default, revealed via .is-success) */
.claim-toast__check {
  position: absolute;
  opacity: 0;
  transform: scale(.5);
  transition:
    opacity 0.22s ease-out,
    transform 0.36s cubic-bezier(.18, .89, .32, 1.4);
}
.claim-toast.is-success .claim-toast__check {
  opacity: 1;
  transform: scale(1);
}

.claim-toast__amount {
  color: #fff;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
  line-height: 1.15;
  text-align: center;
  white-space: nowrap;
}

.claim-toast__label {
  color: rgba(255, 255, 255, 0.75);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0;
  margin-top: 4px;
  text-align: center;
}

/* ============================================================ */
/* === Day item — 3 estados (completed default / active / reset) */
/* ============================================================ */

/* ACTIVE — Dia 6 clicável (vermelho TikTok solid, sem pulse) */
#one .day-tracker__item--active {
  cursor: pointer;
  outline: none;
}
#one .day-tracker__item--active:focus-visible {
  outline: 2px solid #FE2C55;
  outline-offset: 2px;
  border-radius: 12px;
}

#one .day-tracker__box--active {
  background: #FE2C55 !important;
  border: 0 !important;
  box-shadow: 0 4px 12px rgba(254, 44, 85, 0.35);
  transition: background 0.18s ease-out, transform 0.12s ease-out;
}
#one .day-tracker__item--active:hover .day-tracker__box--active {
  background: #E62649 !important;
}
#one .day-tracker__item--active:active .day-tracker__box--active {
  transform: scale(0.94);
  background: #D6213F !important;
}

#one .day-tracker__item--active .day-tracker__value {
  color: #fff !important;
  font-weight: 800 !important;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.18);
}
#one .day-tracker__item--active .day-tracker__coin img {
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.3));
}
/* Label "Dia 06" mantém cor padrão (cinza igual os outros) */

/* LOADING — Dia 6 durante claim (spinner branco no centro) */
#one .day-tracker__item--active.is-loading {
  pointer-events: none;
  cursor: default;
}
#one .day-tracker__item--active.is-loading .day-tracker__content {
  visibility: hidden;
}
#one .day-tracker__item--active.is-loading .day-tracker__box::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 18px;
  height: 18px;
  margin-top: -9px;
  margin-left: -9px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-top-color: #fff;
  animation: btnSpin 0.7s linear infinite;
}
#one .day-tracker__item--active.is-loading .day-tracker__box {
  position: relative;
}

/* RESET — Dia padrão pós-claim (cinza claro com coin amarela visível) */
#one .day-tracker__item--reset {
  cursor: default !important;
  pointer-events: none;
  animation: dayResetSettle 0.55s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}
#one .day-tracker__item--reset .day-tracker__box {
  background: #F5F5F5 !important;
  border: 1px solid #EAEAEA !important;
  box-shadow: none !important;
}
#one .day-tracker__item--reset .day-tracker__overlay {
  opacity: 0 !important;
  transform: scale(0.7) !important;
  pointer-events: none;
}
#one .day-tracker__item--reset .day-tracker__value {
  color: #161823 !important;
  font-weight: 700 !important;
  text-shadow: none !important;
  transition: color 0.45s ease;
}
#one .day-tracker__item--reset .day-tracker__coin {
  opacity: 1 !important;
  transition: opacity 0.45s ease 0.1s;
}
#one .day-tracker__item--reset .day-tracker__coin img {
  filter: none !important;
  transition: filter 0.45s ease;
}
#one .day-tracker__item--reset .day-tracker__label {
  color: #86878B !important;
  font-weight: 600 !important;
  transition: color 0.45s ease;
}

/* Stagger cascata: cada dia entra no reset com pequeno delay */
#one .day-tracker__item--reset:nth-child(1) { animation-delay: 0.00s; }
#one .day-tracker__item--reset:nth-child(2) { animation-delay: 0.05s; }
#one .day-tracker__item--reset:nth-child(3) { animation-delay: 0.10s; }
#one .day-tracker__item--reset:nth-child(4) { animation-delay: 0.15s; }
#one .day-tracker__item--reset:nth-child(5) { animation-delay: 0.20s; }
#one .day-tracker__item--reset:nth-child(6) { animation-delay: 0.25s; }
#one .day-tracker__item--reset:nth-child(7) { animation-delay: 0.30s; }

#one .day-tracker__item--reset:nth-child(1) .day-tracker__overlay { transition-delay: 0.00s; }
#one .day-tracker__item--reset:nth-child(2) .day-tracker__overlay { transition-delay: 0.05s; }
#one .day-tracker__item--reset:nth-child(3) .day-tracker__overlay { transition-delay: 0.10s; }
#one .day-tracker__item--reset:nth-child(4) .day-tracker__overlay { transition-delay: 0.15s; }
#one .day-tracker__item--reset:nth-child(5) .day-tracker__overlay { transition-delay: 0.20s; }
#one .day-tracker__item--reset:nth-child(6) .day-tracker__overlay { transition-delay: 0.25s; }
#one .day-tracker__item--reset:nth-child(7) .day-tracker__overlay { transition-delay: 0.30s; }

#one .day-tracker__item--reset:nth-child(1) .day-tracker__box { transition-delay: 0.00s; }
#one .day-tracker__item--reset:nth-child(2) .day-tracker__box { transition-delay: 0.05s; }
#one .day-tracker__item--reset:nth-child(3) .day-tracker__box { transition-delay: 0.10s; }
#one .day-tracker__item--reset:nth-child(4) .day-tracker__box { transition-delay: 0.15s; }
#one .day-tracker__item--reset:nth-child(5) .day-tracker__box { transition-delay: 0.20s; }
#one .day-tracker__item--reset:nth-child(6) .day-tracker__box { transition-delay: 0.25s; }
#one .day-tracker__item--reset:nth-child(7) .day-tracker__box { transition-delay: 0.30s; }

@keyframes dayResetSettle {
  0%   { transform: scale(1) translateY(0); }
  35%  { transform: scale(0.92) translateY(2px); }
  70%  { transform: scale(1.04) translateY(-1px); }
  100% { transform: scale(1) translateY(0); }
}

/* ============================================================ */
/* Bloco "Ver vídeos" — polish TikTok Bonus oficial             */
/* ============================================================ */

/* Título: maior, peso 800, com pontos em vermelho */
#one .bloco-dois .entre-txt-dois {
  font-family: "TikTok Sans", "Inter", system-ui, -apple-system, sans-serif;
  font-weight: 800;
  color: #161823;
  font-size: 16px;
  letter-spacing: -0.3px;
  line-height: 1.25;
}
#one .bloco-dois .entre-pts {
  color: #FE2C55;
  font-weight: 800;
  font-size: 16px;
  letter-spacing: -0.3px;
  display: inline;
}

/* Tooltip "Vê durante 10 min" — pill compacta com bico apontando pra cima */
#one .bloco-dois .assista {
  background: #F4F4F4;
  height: 22px;
  width: auto !important;
  max-width: fit-content;
  padding: 0 12px;
  border-radius: 999px;
  box-shadow: none;
  margin-left: 0;
  margin-top: 12px;
  align-self: flex-start;
  display: inline-flex;
  position: relative;
}
#one .bloco-dois .assista-txt {
  color: #161823;
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-weight: 600;
  font-size: 11.5px;
  letter-spacing: -0.1px;
  white-space: nowrap;
}
/* Bico aponta pra CIMA (em direção aos pontos acima) */
#one .bloco-dois .assista-tail {
  top: auto !important;
  bottom: 100% !important;
  left: 18px !important;
  margin-top: 0 !important;
  margin-bottom: -1px;
  transform: rotate(180deg);
}
#one .bloco-dois .assista-tail path {
  fill: #F4F4F4 !important;
}

/* Layout — TODOS os .entre em bloco-dois: botão à direita centralizado */
#one .bloco-dois .entre {
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  position: relative;
}
#one .bloco-dois .entre:has(.entre-data) {
  padding-bottom: 24px;
}
#one .bloco-dois .entre .entre-txt,
#one .bloco-dois .entre .entre-txt-dois {
  flex: 1 1 auto;
  width: auto;
  min-width: 0;
  padding-right: 0;
}
#one .bloco-dois .entre .btn-concluido {
  flex-shrink: 0;
  align-self: center;
}
/* entre-data fica posicionada ABAIXO da row, sem afetar o centro do flex */
#one .bloco-dois .entre .entre-data {
  position: absolute;
  bottom: 2px;
  left: 0;
  margin-top: 0 !important;
}

/* Progress bar — linha fininha estilo TikTok oficial */
#one .bloco-dois .progress-bar {
  margin-top: 18px;
  padding: 0 14px;
}
#one .bloco-dois .progress-bar::before {
  height: 5px;
  background: #E8DCC8;
  top: 11px;
  border-radius: 99px;
  left: 0;
  right: 0;
}
#one .bloco-dois .progress-bar--filled::after {
  height: 5px;
  top: 11px;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  border-radius: 99px;
  background: #FE2C55 !important;
  box-shadow: none;
}
#one .bloco-dois .progress-bar--filled {
  position: relative;
}
#one .bloco-dois .progress-bar--filled .step-icon {
  z-index: 2;
}

/* Step icon (moeda) — só a SVG, sem fundo */
#one .bloco-dois .progress-step {
  gap: 8px;
}
#one .bloco-dois .progress-step .step-icon {
  width: 28px;
  height: 28px;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
  transition: transform 0.2s ease;
  padding: 0 !important;
}
#one .bloco-dois .progress-step--completed .step-icon {
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
  filter: none;
}
#one .bloco-dois .progress-step--completed .step-icon img {
  filter: none;
  width: 100%;
  height: 100%;
  margin: 0;
}
#one .bloco-dois .progress-step--completed .step-text {
  color: #161823;
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: -0.1px;
  margin-top: 2px;
}

/* Step expired — moeda igual às outras */
#one .bloco-dois .progress-step--expired {
  opacity: 1;
}
#one .bloco-dois .progress-step--expired .step-icon {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  filter: none !important;
}
#one .bloco-dois .progress-step--expired .step-icon img {
  opacity: 1;
  width: 100%;
  height: 100%;
  margin: 0;
  filter: none !important;
}

/* Estado pós-claim — barra reseta visualmente pra default */
#one .bloco-dois .progress-bar--filled.is-reset::after {
  width: 0% !important;
  transition: width 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
#one .bloco-dois .progress-bar--filled.is-reset .progress-step .step-icon {
  filter: grayscale(0.6) opacity(0.85) !important;
  transition: filter 0.5s ease 0.15s;
}
#one .bloco-dois .progress-bar--filled.is-reset .progress-step .step-text {
  color: #161823;
  transition: color 0.5s ease;
}
#one .bloco-dois .progress-step--expired .step-text {
  color: #161823;
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-weight: 600;
  font-size: 12px;
  text-decoration: none;
  margin-top: 2px;
}
/* X overlay removido */
#one .bloco-dois .progress-step--expired::before {
  content: none !important;
  display: none !important;
}

/* Linha divisória sutil */
#one .bloco-dois .line.line-dois {
  background: #F1F1F3;
  height: 1px;
  margin: 14px 0;
}

/* Texto explicativo "Obtém 21 pontos..." — largura máxima */
#one .bloco-dois .obtem .obtem-txt {
  width: 100%;
  max-width: 100%;
  margin-left: 0;
  display: block;
  color: #86878B;
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 11.5px;
  font-weight: 500;
  line-height: 1.45;
  letter-spacing: -0.05px;
}

/* ============================================================ */
/* Sticky Saldo Bar — polish TikTok Pay                         */
/* ============================================================ */

#one .saldo,
#popup-um .saldo {
  padding: 14px 16px;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04), 0 8px 28px rgba(0, 0, 0, 0.06);
  border: 1px solid rgba(22, 24, 35, 0.04);
}
#popup-um .container-saldo {
  padding: 0 !important;
}

#one .saldo .container-saldo,
#popup-um .saldo .container-saldo {
  align-items: center !important;
  gap: 14px;
}

#one .saldo .saldo-info,
#popup-um .saldo .saldo-info {
  gap: 4px;
}

#one .saldo .saldo-label,
#popup-um .saldo .saldo-label {
  gap: 5px;
}
#one .saldo .saldo-text,
#popup-um .saldo .saldo-text {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  color: #5A5B61;
  font-size: 12.5px;
  font-weight: 600;
  letter-spacing: -0.1px;
  line-height: 1;
}
#one .saldo .p-saldo,
#popup-um .saldo .p-saldo {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

#one .saldo .saldo-valor,
#popup-um .saldo .saldo-valor {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
#one .saldo .saldo-valor .valor-currency,
#popup-um .saldo .saldo-valor .valor-currency {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  font-size: 26px;
  font-weight: 800;
  color: #161823;
  letter-spacing: -0.6px;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1, "lnum" 1;
  align-self: center;
}
#one .saldo .saldo-valor .saldo-pontos,
#popup-um .saldo .saldo-valor .saldo-pontos {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  color: #86878B;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.1px;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
  margin-top: 0;
  line-height: 1;
  align-self: flex-end;
  transform: translateY(-3px);
}

#one .saldo .saldo-action,
#popup-um .saldo .saldo-action {
  align-self: center;
  align-items: center;
  position: relative;
}

/* Badge PIX acima do botão Sacar — formato tag (3 cantos redondos) */
#one .saldo .pix-badge,
#popup-um .saldo .pix-badge,
#one .saldo .mbway-badge,
#popup-um .saldo .mbway-badge {
  position: absolute;
  top: -14px;
  right: -4px;
  z-index: 2;
  background: #fff;
  padding: 3px 8px;
  border-radius: 9px 9px 9px 0;
  box-shadow:
    0 3px 6px rgba(0, 0, 0, 0.16),
    0 8px 20px rgba(0, 0, 0, 0.12);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
#one .saldo .pix-badge img,
#popup-um .saldo .pix-badge img {
  width: 32px;
  height: 18px;
  object-fit: contain;
  display: block;
}
#one .saldo .mbway-badge img,
#popup-um .saldo .mbway-badge img {
  width: 30px;
  height: 19px;
  object-fit: contain;
  display: block;
  image-rendering: -webkit-optimize-contrast;
  image-rendering: crisp-edges;
}

/* Botão "Sacar" — pill vermelho consistente (sombra estática, sem pulse) */
#one .saldo .btn-sacar,
#popup-um .saldo .btn-sacar {
  width: auto !important;
  height: auto !important;
  min-width: 96px !important;
  padding: 11px 22px !important;
  border-radius: 999px !important;
  background: #FE2C55 !important;
  border: 0 !important;
  cursor: pointer;
  transition: background 0.15s ease, box-shadow 0.2s ease;
  align-self: center;
  position: relative;
  z-index: 1;
  box-shadow: 0 4px 14px rgba(254, 44, 85, 0.32);
}
#one .saldo .btn-sacar:not(:disabled):hover,
#popup-um .saldo .btn-sacar:not(:disabled):hover {
  background: #E62649 !important;
  box-shadow: 0 6px 18px rgba(254, 44, 85, 0.42) !important;
}
#one .saldo .btn-sacar:not(:disabled):active,
#popup-um .saldo .btn-sacar:not(:disabled):active {
  transform: scale(0.96);
  box-shadow: 0 2px 8px rgba(254, 44, 85, 0.32) !important;
}
#one .saldo .btn-sacar:disabled,
#popup-um .saldo .btn-sacar:disabled {
  opacity: 1;
  cursor: not-allowed;
}
#one .saldo .btn-sacar .btn-text,
#popup-um .saldo .btn-sacar .btn-text {
  font-family: "TikTok Sans", "Inter", system-ui, sans-serif;
  color: #fff;
  font-size: 13.5px;
  font-weight: 800;
  letter-spacing: -0.2px;
}

/* Pulse sutil quando o saldo está animando (incrementando) */
@keyframes saldoBumpPulse {
  0%   { transform: scale(1); }
  40%  { transform: scale(1.045); }
  100% { transform: scale(1); }
}
#one .saldo .saldo-valor .valor-currency.is-animating,
#popup-um .saldo .saldo-valor .valor-currency.is-animating {
  animation: saldoBumpPulse 0.6s cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* Reduce-motion respect */
@media (prefers-reduced-motion: reduce) {
  .claim-toast__loader { animation: none !important; }
  .claim-toast,
  .claim-toast__check,
  .claim-toast__loader { transition: opacity 0.15s ease-out !important; }
}

/* ============================================================ */
/* === Saldo card — valor em pontos ao lado do €              === */
/* ============================================================ */

#one #saldo-valor {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 6px;
}

#one .saldo-pontos {
  font-size: 13px;
  font-weight: 500;
  color: #FE2C55;
  letter-spacing: -0.005em;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  white-space: nowrap;
}

@media (max-width: 380px) {
  #one .saldo-pontos { font-size: 12px; }
}

/* Parabéns! — valor em cima, pontos embaixo */
#one .parabens-valor-wrap {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
}
#one .parabens-pontos {
  font-size: 12px;
  font-weight: 500;
}

/* Esconde "+X pontos" do bloco após claim (fade out + collapse) */
#one .streak-pts {
  transition:
    opacity 0.32s ease-out,
    max-height 0.32s ease-out,
    margin 0.32s ease-out;
  overflow: hidden;
  max-height: 30px;
}
#one .streak-pts.streak-pts-hidden {
  opacity: 0;
  max-height: 0;
  margin: 0 !important;
  pointer-events: none;
}

