/* =========================
   PATCH PRESser — HERO BOTÃO + AUTH BUTTONS
   (não depende do resto do seu CSS)
   ========================= */

/* NAVBAR: garante altura e evita “invadir” o hero */
.navbar{
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 9999;
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(15,36,81,.18);
}

.nav-container{
  height: 80px;                     /* padrão */
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: min(1200px, 92%);
  margin: 0 auto;
}

/* Evita o “Criar conta” cair pra baixo */
.spacer{ height: 80px !important; }

/* BOTÕES DO TOPO (Iniciar Sessão / Criar Conta)
   -> funciona com suas classes atuais: .btn-ghost e .btn-primary */
.btn-ghost, .btn-primary{
  all: unset;                       /* mata estilos antigos conflitantes */
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;

  font-family: "Poppins", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 800;
  font-size: 14px;
  line-height: 1;

  padding: 12px 18px;
  border-radius: 999px;
  white-space: nowrap;

  transition: transform .15s ease, filter .15s ease, background .15s ease;
}

.btn-ghost{
  background: #ffffff;
  color: #0f2451;
  border: 1px solid rgba(15,36,81,.35);
}
.btn-ghost:hover{ filter: brightness(0.98); transform: translateY(-1px); }

.btn-primary{
  background: #0f2451;
  color: #ffffff;
  border: 1px solid rgba(15,36,81,.0);
}
.btn-primary:hover{ filter: brightness(1.05); transform: translateY(-1px); }

/* HERO: garante que o conteúdo não fica atrás da navbar */
.hero{
  padding-top: 120px !important;   /* empurra título+botão pra baixo da navbar */
}

/* BOTÃO DO HERO (Começar a Investir Agora) */
.hero .botao-investir{
  all: unset;                      /* elimina o “barra branca” e estilos globais */
  box-sizing: border-box;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  font-family: "Poppins", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 900;
  font-size: 15px;
  letter-spacing: 1.1px;
  text-transform: uppercase;

  color: #ffffff;
  background: linear-gradient(90deg, #071b3a 0%, #0f2f63 100%);
  border-radius: 999px;
  padding: 14px 28px;

  cursor: pointer;
  position: relative;
  z-index: 1;

  box-shadow: 0 12px 28px rgba(7,27,58,.55);
  transition: transform .25s ease, filter .25s ease;
}

/* aro externo */
.hero .botao-investir::before{
  content: "";
  position: absolute;
  inset: -7px;
  border-radius: 999px;
  border: 2px solid #1e4f91;
  box-shadow: 0 0 36px rgba(30,79,145,.55);
  opacity: 0;
  transition: opacity .25s ease;
  pointer-events: none;
}

/* pulso */
.hero .botao-investir::after{
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 24px;
  height: 24px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  border: 2px solid #1e4f91;
  opacity: .9;
  animation: presserRing 1.5s infinite;
  pointer-events: none;
}

.hero .botao-investir:hover{
  transform: translateY(-4px);
  filter: brightness(1.05);
}

.hero .botao-investir:hover::before{ opacity: 1; }
.hero .botao-investir:hover::after{ animation: none; display: none; }

@keyframes presserRing{
  0%   { width: 24px;  height: 24px;  opacity: 1; }
  100% { width: 260px; height: 260px; opacity: 0; }
}

/* Mobile */
@media (max-width: 600px){
  .hero .botao-investir{
    width: min(320px, 92vw);
    font-size: 13.5px;
    padding: 14px 18px;
  }

  .btn-ghost, .btn-primary{
    padding: 10px 12px;
    font-size: 12px;
  }

/* =========================
   HERO — NÃO PERCA MAIS TEMPO + JANELA
   ========================= */

.hero-navy{
  position: relative !important;
  background: radial-gradient(1200px 600px at 30% 20%, #0f1f3f 0%, #07162f 40%, #050f22 100%) !important;
  padding: 120px 0 120px !important;
  color: #ffffff !important;
}

.hero-navy .wrap{
  width: min(1200px, 92%) !important;
  margin: 0 auto !important;
}

/* =========================
   GRID LADO A LADO
   ========================= */

.cta-container{
  display: grid !important;
  grid-template-columns: 1.25fr 0.75fr !important; /* texto maior, card menor */
  gap: 48px !important;
  align-items: center !important;
}

/* =========================
   COLUNA ESQUERDA
   ========================= */

.left h1{
  font-size: clamp(2.5rem, 4vw, 3.5rem) !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  margin-bottom: 18px !important;
}

.left .lead{
  max-width: 520px !important;
  font-size: 1rem !important;
  line-height: 1.6 !important;
  color: rgba(255,255,255,.88) !important;
  margin-bottom: 28px !important;
}

.steps{
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 32px !important;
  display: grid !important;
  gap: 16px !important;
}

.steps li{
  display: flex !important;
  gap: 12px !important;
  align-items: flex-start !important;
}

.steps .ico{
  min-width: 36px !important;
  height: 36px !important;
  border-radius: 10px !important;
  display: grid !important;
  place-items: center !important;
  background: rgba(255,255,255,.08) !important;
  color: #7aa2ff !important;
}

.steps b{
  font-size: .9rem !important;
  display: block !important;
}

.steps span{
  font-size: .8rem !important;
  color: rgba(255,255,255,.7) !important;
}

/* =========================
   BOTÃO
   ========================= */

.btn.cta{
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 12px 22px !important;
  border-radius: 999px !important;
  background: linear-gradient(90deg, #2563eb, #4f46e5) !important;
  color: #fff !important;
  font-weight: 600 !important;
  font-size: .9rem !important;
  text-decoration: none !important;
  box-shadow: 0 10px 30px rgba(37,99,235,.35) !important;
  transition: all .25s ease !important;
}

.btn.cta:hover{
  transform: translateY(-2px) !important;
  box-shadow: 0 14px 40px rgba(37,99,235,.45) !important;
}

/* =========================
   CARD — JANELA DE ENTRADA
   ========================= */

.card{
  background: #ffffff !important;
  color: #0f172a !important;
  border-radius: 18px !important;
  padding: 22px !important;
  max-width: 420px !important;
  width: 100% !important;
  box-shadow: 0 30px 80px rgba(0,0,0,.25) !important;
  position: relative !important;
}

/* CABEÇALHO */

.card-head{
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 14px !important;
  font-size: .9rem !important;
  font-weight: 700 !important;
}

.card-head .head-ico{
  width: 32px !important;
  height: 32px !important;
  border-radius: 10px !important;
  background: #eef2ff !important;
  color: #1e3a8a !important;
  display: grid !important;
  place-items: center !important;
}

/* =========================
   CONTADOR
   ========================= */

.countdown{
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 10px !important;
  margin-bottom: 10px !important;
}

.countdown .slot{
  background: #f8fafc !important;
  border-radius: 12px !important;
  padding: 10px 6px !important;
  text-align: center !important;
  border: 1px solid #e5e7eb !important;
}

.countdown .num{
  display: block !important;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  line-height: 1 !important;
}

.countdown .lbl{
  display: block !important;
  font-size: .7rem !important;
  color: #64748b !important;
  margin-top: 4px !important;
}

.muted{
  font-size: .75rem !important;
  color: #64748b !important;
  text-align: center !important;
  margin-bottom: 14px !important;
}

/* =========================
   LISTA DE INFORMAÇÕES
   ========================= */

.info-list{
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 12px !important;
  display: grid !important;
  gap: 10px !important;
}

.info-list li{
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  background: #f8fafc !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 12px !important;
  padding: 10px 12px !important;
}

.info-list .i{
  width: 28px !important;
  height: 28px !important;
  border-radius: 8px !important;
  background: #eef2ff !important;
  color: #1e3a8a !important;
  display: grid !important;
  place-items: center !important;
}

.info-list .title{
  display: block !important;
  font-size: .75rem !important;
  color: #64748b !important;
}

.info-list .value{
  font-size: .9rem !important;
  font-weight: 700 !important;
}

/* =========================
   BADGES
   ========================= */

.badges{
  list-style: none !important;
  padding: 0 !important;
  margin: 8px 0 0 !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}

.badges li{
  font-size: .7rem !important;
  padding: 4px 10px !important;
  border-radius: 999px !important;
  background: #eef2ff !important;
  color: #1e3a8a !important;
  font-weight: 600 !important;
}

/* =========================
   FAIXA DE DESCONTO
   ========================= */

.ribbon{
  margin-top: 12px !important;
  padding: 8px !important;
  border-radius: 10px !important;
  background: #f1f5f9 !important;
  border: 1px dashed #c7d2fe !important;
  font-size: .75rem !important;
  text-align: center !important;
  font-weight: 700 !important;
  color: #1e3a8a !important;
}

.ribbon .warn{
  margin-right: 6px !important;
}

/* =========================
   RESPONSIVO
   ========================= */

@media (max-width: 900px){
  .cta-container{
    grid-template-columns: 1fr !important;
  }

  .card{
    max-width: 100% !important;
    margin-top: 32px !important;
  }
}

/* =========================
   FORÇA HERO (#entrada) EM 2 COLUNAS
   ========================= */

section.hero-navy#entrada .wrap .cta-container{
  display: grid !important;
  grid-template-columns: minmax(0, 1.25fr) minmax(320px, 0.75fr) !important;
  gap: 48px !important;
  align-items: center !important;

  /* mata qualquer herança de flex */
  flex-direction: unset !important;
  flex-wrap: unset !important;
}

/* garante que a coluna esquerda não “empurre” e quebre o grid */
section.hero-navy#entrada .wrap .cta-container > .left{
  min-width: 0 !important;
}

/* card menor e fixado à direita */
section.hero-navy#entrada .wrap .cta-container > aside.card{
  width: 100% !important;
  max-width: 420px !important;
  justify-self: end !important;
  margin: 0 !important; /* mata margin-top antigo que joga o card pra baixo */
}

/* mobile */
@media (max-width: 900px){
  section.hero-navy#entrada .wrap .cta-container{
    grid-template-columns: 1fr !important;
  }
  section.hero-navy#entrada .wrap .cta-container > aside.card{
    max-width: 100% !important;
  }
}

/* ============================================
   FIX DEFINITIVO: HERO (#entrada) 2 COLUNAS
   (usa FLEX e zera regras antigas que empilham)
   ============================================ */

section#entrada.hero-navy .cta-container{
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 48px !important;

  /* mata qualquer layout antigo */
  grid-template-columns: unset !important;
  grid-auto-flow: unset !important;
}

section#entrada.hero-navy .cta-container > .left{
  flex: 1 1 auto !important;
  min-width: 0 !important;
  max-width: 640px !important; /* evita a esquerda “dominar” tudo */
}

section#entrada.hero-navy .cta-container > aside.card{
  flex: 0 0 420px !important;  /* largura fixa menor */
  width: 420px !important;
  max-width: 420px !important;

  /* zera regras que podem estar forçando 100% */
  grid-column: auto !important;
  justify-self: auto !important;
  align-self: center !important;
  margin: 0 !important;
}

/* Responsivo: empilha no mobile */
@media (max-width: 980px){
  section#entrada.hero-navy .cta-container{
    flex-direction: column !important;
    align-items: stretch !important;
  }

  section#entrada.hero-navy .cta-container > .left{
    max-width: 100% !important;
  }

  section#entrada.hero-navy .cta-container > aside.card{
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 auto !important;
    margin-top: 24px !important;
  }
}

/* ============================================
   ENTRADA 2 COLUNAS — FORÇA TOTAL
   ============================================ */

section#entrada.hero-navy .cta-container.entrada-2col{
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 48px !important;

  /* mata qualquer coisa que esteja te derrubando */
  text-align: left !important;
  height: auto !important;
  grid-template-columns: unset !important;
}

section#entrada.hero-navy .cta-container.entrada-2col > .left{
  flex: 1 1 620px !important;
  max-width: 680px !important;
  min-width: 0 !important;
}

section#entrada.hero-navy .cta-container.entrada-2col > aside.card{
  flex: 0 0 420px !important;
  width: 420px !important;
  max-width: 420px !important;

  margin: 0 !important;
  grid-column: auto !important;
  justify-self: auto !important;
  align-self: center !important;
}

/* Mobile */
@media (max-width: 980px){
  section#entrada.hero-navy .cta-container.entrada-2col{
    flex-direction: column !important;
    align-items: stretch !important;
    text-align: left !important;
  }
  section#entrada.hero-navy .cta-container.entrada-2col > aside.card{
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 auto !important;
    margin-top: 24px !important;
  }
}

}
