:root {
  --vermelho: #e2211c;
  --vermelho-esc: #c01a16;
  --verde: #00943a;
  --verde-esc: #007d31;
  --preto: #1a1a1a;
  --texto: #1f2430;
  --muted: #6b7280;
  --bg: #ffffff;
  --bg2: #f6f7f9;
  --bg3: #eef0f3;
  --borda: #e5e7eb;
  --sombra: 0 4px 24px rgba(20, 24, 40, .07);
  --sombra-ft: 0 10px 40px rgba(20, 24, 40, .12);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  font-family: 'Archivo', system-ui, sans-serif;
  background: var(--bg);
  color: var(--texto);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

.hidden { display: none !important; }
.red { color: var(--vermelho); }
.green { color: var(--verde); }
.center { text-align: center; }

/* ============================ BOTÕES ============================ */
.btn {
  display: inline-block;
  background: var(--vermelho);
  color: #fff;
  font-family: 'Archivo', sans-serif;
  font-weight: 700;
  font-size: .95rem;
  letter-spacing: .4px;
  text-transform: uppercase;
  text-decoration: none;
  text-align: center;
  padding: 13px 30px;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  transition: transform .12s ease, box-shadow .2s ease, background .2s ease;
  box-shadow: 0 6px 18px rgba(226, 33, 28, .25);
}
.btn:hover { background: var(--vermelho-esc); transform: translateY(-2px); box-shadow: 0 10px 26px rgba(226,33,28,.32); }
.btn--lg { font-size: 1.1rem; padding: 16px 40px; }
.btn--full { width: 100%; }
.btn--green { background: var(--verde); box-shadow: 0 6px 18px rgba(0,148,58,.25); }
.btn--green:hover { background: var(--verde-esc); box-shadow: 0 10px 26px rgba(0,148,58,.32); }
.btn--ghost { background: #fff; color: var(--texto); border: 1.5px solid var(--borda); box-shadow: none; }
.btn--ghost:hover { background: var(--bg2); color: var(--texto); border-color: #cbd0d8; }

/* ============================ BANNER ============================ */
.topbar { height: 6px; background: linear-gradient(90deg, var(--vermelho) 0 60%, var(--verde) 60% 100%); }

.banner {
  position: relative;
  text-align: center;
  padding: 56px 20px 64px;
  background:
    radial-gradient(1200px 400px at 50% -10%, #fff 0%, var(--bg2) 70%);
  border-bottom: 1px solid var(--borda);
}
.banner__gb { height: 34px; width: auto; margin-bottom: 26px; opacity: .95; }
.banner__gbk { height: clamp(96px, 22vw, 180px); width: auto; }
.banner__kicker {
  font-weight: 600; letter-spacing: .35em; text-transform: uppercase;
  color: var(--muted); font-size: clamp(.75rem, 2vw, .95rem); margin: 26px 0 8px;
}
.banner__title {
  font-family: 'Anton', sans-serif;
  font-size: clamp(2rem, 7vw, 4.2rem);
  line-height: 1; text-transform: uppercase; color: var(--preto);
}

.event-card {
  display: inline-flex; flex-wrap: wrap; gap: 0;
  margin: 34px auto 0; background: #fff;
  border: 1px solid var(--borda); border-radius: 16px;
  box-shadow: var(--sombra); overflow: hidden;
}
.event-card .ec {
  padding: 18px 26px; min-width: 150px; border-right: 1px solid var(--borda);
}
.event-card .ec:last-child { border-right: none; }
.event-card .ec small { display: block; color: var(--muted); font-size: .72rem; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 4px; }
.event-card .ec b { font-family: 'Anton', sans-serif; font-size: 1.5rem; font-weight: 400; color: var(--preto); letter-spacing: .5px; }
.event-card .ec.red b { color: var(--vermelho); }

.banner .btn { margin-top: 34px; }

/* ====================== FAIXA DE LOTE ====================== */
.strip {
  background: var(--preto); color: #fff;
  display: flex; align-items: center; justify-content: center;
  gap: 22px; flex-wrap: wrap; padding: 16px 6vw; text-align: center;
}
.strip__label { font-size: .72rem; letter-spacing: 3px; text-transform: uppercase; opacity: .7; }
.strip__valor { font-family: 'Anton', sans-serif; font-size: 1.5rem; }
.strip .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--verde); display: inline-block; }

/* ============================ SEÇÕES ============================ */
.sec { padding: 76px 6vw; }
.sec--alt { background: var(--bg2); }
.wrap { max-width: 1080px; margin: 0 auto; }
.wrap--narrow { max-width: 720px; }

.sec__eyebrow { color: var(--vermelho); font-weight: 700; letter-spacing: 2px; text-transform: uppercase; font-size: .8rem; margin-bottom: 8px; }
.sec__title {
  font-family: 'Anton', sans-serif; font-weight: 400;
  font-size: clamp(1.6rem, 4vw, 2.6rem); text-transform: uppercase;
  line-height: 1.08; color: var(--preto); margin-bottom: 14px;
}
.sub { font-family: 'Anton', sans-serif; font-weight: 400; font-size: clamp(1.3rem, 3.5vw, 1.9rem); text-transform: uppercase; margin: 54px 0 24px; text-align: center; color: var(--preto); }

.chamada { font-size: clamp(1.15rem, 3vw, 1.6rem); font-weight: 700; color: var(--preto); line-height: 1.25; margin-bottom: 14px; max-width: 820px; }
.paragrafo { font-size: 1.08rem; color: var(--muted); max-width: 820px; }

.bullets { list-style: none; display: grid; grid-template-columns: repeat(auto-fit, minmax(280px,1fr)); gap: 18px; margin-top: 28px; }
.bullets li { background: #fff; border: 1px solid var(--borda); border-radius: 14px; padding: 22px; box-shadow: var(--sombra); }
.bullets .chk { color: var(--verde); font-weight: 800; margin-right: 6px; }
.bullets b { display: block; font-size: 1.12rem; margin-bottom: 6px; color: var(--preto); }
.bullets span { color: var(--muted); }

/* ============================ CRONOGRAMA ============================ */
.crono { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; margin-top: 10px; }
.crono__col { background: #fff; border: 1px solid var(--borda); border-radius: 16px; padding: 26px; box-shadow: var(--sombra); }
.crono__head { font-family: 'Anton', sans-serif; font-size: 1.4rem; text-transform: uppercase; color: var(--preto); margin-bottom: 18px; padding-bottom: 12px; border-bottom: 2px solid var(--bg3); }
.crono__item { display: flex; gap: 16px; padding: 12px 0; border-bottom: 1px solid var(--bg2); }
.crono__item:last-child { border-bottom: none; }
.crono__hora { flex: 0 0 52px; font-family: 'Anton', sans-serif; color: var(--vermelho); font-size: 1.1rem; }
.crono__txt b { color: var(--preto); }
.crono__mod { background: var(--bg2); border-left: 3px solid var(--verde); border-radius: 8px; padding: 12px 14px; margin: 6px 0; }
.crono__mod .mtit { font-weight: 700; color: var(--preto); margin-bottom: 6px; }
.crono__mod ul { margin: 0; padding-left: 18px; color: var(--muted); font-size: .95rem; }
.crono__mod li { margin-bottom: 4px; }

/* ============================ LOTES ============================ */
.lotes { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 22px; }
.lote-card { background: #fff; border: 1.5px solid var(--borda); border-radius: 16px; padding: 30px 26px; position: relative; box-shadow: var(--sombra); transition: transform .15s, box-shadow .2s; }
.lote-card--ativo { border-color: var(--vermelho); box-shadow: 0 14px 40px rgba(226,33,28,.16); }
.lote-card--encerrado { opacity: .55; }
.lote-card__tag { position: absolute; top: -12px; left: 26px; background: var(--vermelho); color: #fff; font-weight: 700; font-size: .72rem; letter-spacing: 1.5px; padding: 5px 13px; border-radius: 20px; text-transform: uppercase; }
.lote-card__tag--off { background: #9ca3af; }
.lote-card h4 { font-family: 'Anton', sans-serif; font-weight: 400; font-size: 1.5rem; text-transform: uppercase; color: var(--preto); }
.lote-card .prazo { color: var(--muted); font-size: .95rem; margin-bottom: 16px; }
.lote-card .preco { font-family: 'Anton', sans-serif; font-weight: 400; font-size: 2.6rem; color: var(--preto); line-height: 1; }
.lote-card .preco small { font-size: .9rem; color: var(--muted); display: block; font-family: 'Archivo'; margin-top: 4px; }
.lote-card .cartao { margin-top: 12px; color: var(--muted); }

/* ============================ DESCONTOS ============================ */
.descontos { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 18px; }
.desc-card { background: #fff; border: 1px solid var(--borda); border-radius: 16px; padding: 28px 18px; text-align: center; box-shadow: var(--sombra); }
.desc-card .pct { font-family: 'Anton', sans-serif; font-size: 2.6rem; color: var(--verde); line-height: 1; }
.desc-card .qtd { color: var(--muted); font-weight: 600; margin-top: 6px; }
.desc-nota { text-align: center; color: var(--muted); margin-top: 20px; font-size: .98rem; }
.desc-nota b { color: var(--preto); }

/* ============================ FORMULÁRIO ============================ */
.form { display: grid; gap: 18px; margin-top: 14px; background: #fff; border: 1px solid var(--borda); border-radius: 18px; padding: 30px; box-shadow: var(--sombra); }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.campo { display: flex; flex-direction: column; gap: 6px; }
.campo label { font-weight: 600; font-size: .92rem; color: var(--preto); }
.campo input, .campo select, .campo textarea {
  background: #fff; border: 1.5px solid var(--borda); border-radius: 10px;
  color: var(--texto); font-family: 'Archivo'; font-size: 1rem; padding: 12px 14px; transition: border-color .15s;
}
.campo input:focus, .campo select:focus, .campo textarea:focus { outline: none; border-color: var(--vermelho); }
.radios { display: flex; gap: 14px; flex-wrap: wrap; }
.radio { flex: 1; min-width: 140px; display: flex; align-items: center; gap: 10px; font-size: 1rem; cursor: pointer; border: 1.5px solid var(--borda); border-radius: 10px; padding: 12px 14px; transition: border-color .15s, background .15s; }
.radio:has(input:checked) { border-color: var(--vermelho); background: #fff5f5; }
.hint { color: var(--muted); font-size: .85rem; }
.cpf-hint { color: var(--muted); font-weight: 400; font-size: .8rem; }

/* Cupom */
.cupom-row { display: flex; gap: 10px; }
.cupom-row input { flex: 1; text-transform: uppercase; }
.cupom-feedback { font-size: .92rem; margin-top: 2px; min-height: 1.2em; }
.cupom-feedback.ok { color: var(--verde); font-weight: 600; }
.cupom-feedback.err { color: var(--vermelho); font-weight: 600; }

.resumo { background: var(--bg2); border: 1px solid var(--borda); border-radius: 12px; padding: 18px; font-size: 1rem; display: none; }
.resumo.show { display: block; }
.resumo .linha { display: flex; justify-content: space-between; padding: 4px 0; }
.resumo .linha b { color: var(--preto); }
.resumo .total { border-top: 1px dashed var(--borda); margin-top: 6px; padding-top: 10px; font-family: 'Anton', sans-serif; font-weight: 400; font-size: 1.5rem; }
.resumo .total b { color: var(--vermelho); }

/* ============================ PAGAMENTO ============================ */
.pagamento { background: #fff; border: 1px solid var(--borda); border-radius: 18px; padding: 30px; box-shadow: var(--sombra); margin-top: 14px; }
.confirm { background: #f0faf3; border: 1px solid #b9e6c8; color: var(--verde-esc); border-radius: 12px; padding: 14px 18px; margin-bottom: 18px; text-align: center; font-weight: 600; }
.confirm strong { color: var(--verde); }
.pg-title { font-family: 'Anton', sans-serif; font-weight: 400; font-size: 1.35rem; text-transform: uppercase; color: var(--preto); margin: 18px 0 10px; }
.pg-valor { font-size: 1.1rem; margin-bottom: 14px; color: var(--muted); }
.pg-valor strong { color: var(--vermelho); font-family: 'Anton', sans-serif; font-weight: 400; font-size: 1.6rem; }
.pix-box { display: flex; gap: 24px; flex-wrap: wrap; align-items: flex-start; }
.pix-qr { width: 200px; height: 200px; background: #fff; border: 1px solid var(--borda); border-radius: 12px; padding: 8px; }
.pix-info { flex: 1; min-width: 240px; }
.pix-info p { margin-bottom: 6px; color: var(--muted); }
.pix-info p b { color: var(--preto); }
.pix-label { display: block; margin: 10px 0 4px; font-weight: 600; color: var(--preto); }
.pix-info textarea { width: 100%; background: var(--bg2); border: 1px solid var(--borda); border-radius: 10px; color: var(--texto); padding: 10px; font-size: .82rem; resize: none; word-break: break-all; }
.pix-info .btn { margin-top: 10px; }
.div { border: none; border-top: 1px solid var(--borda); margin: 28px 0; }

.final { text-align: center; padding: 24px 0; }
.final__check { width: 72px; height: 72px; margin: 0 auto 16px; background: var(--verde); border-radius: 50%; color: #fff; font-size: 2.4rem; display: flex; align-items: center; justify-content: center; }
.final h3 { font-family: 'Anton', sans-serif; font-weight: 400; font-size: 1.6rem; text-transform: uppercase; color: var(--preto); }
.final p { color: var(--muted); }
.final__id strong { color: var(--vermelho); }

/* ============================ FOOTER ============================ */
.footer { background: var(--preto); text-align: center; padding: 44px 20px; color: #cfd2d8; }
.footer img { height: 30px; margin-bottom: 14px; }
.footer a { color: #fff; text-decoration: underline; }

/* ============================ TOAST ============================ */
.toast { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%); background: var(--preto); color: #fff; padding: 14px 24px; border-radius: 12px; z-index: 999; font-size: .98rem; box-shadow: var(--sombra-ft); }

/* ============================ RESPONSIVO ============================ */
@media (max-width: 720px) {
  .grid2 { grid-template-columns: 1fr; }
  .crono { grid-template-columns: 1fr; }
  .event-card .ec { border-right: none; border-bottom: 1px solid var(--borda); flex: 1 1 100%; }
  .form, .pagamento { padding: 22px; }
}
