/* ============================================================
   Centauro Lar - Esquenta da Copa
   Identidade própria: azul-marinho + dourado + verde-grama.
   Inspirado em varejo, mas NÃO copia o concorrente.
   ============================================================ */

:root{
  --azul:      #0b2a5b;   /* azul-marinho da marca */
  --azul-claro:#15448f;
  --dourado:   #f7c948;   /* taça / destaque */
  --dourado-d: #c99700;
  --verde:     #1c8a4d;   /* grama / Brasil */
  --verde-esc: #0f5c32;
  --branco:    #ffffff;
  --cinza-bg:  #f4f6fb;
  --cinza-tx:  #4a4f5c;
  --borda:     #e2e6ef;
  --radius:    14px;
  --sombra:    0 6px 24px rgba(11,42,91,.10);
}

*{ box-sizing:border-box; margin:0; padding:0; }
body{
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  background: var(--cinza-bg);
  color: #1a1f2b;
  line-height: 1.55;
}
a{ color: inherit; text-decoration:none; }
.container{ width:100%; max-width:1080px; margin:0 auto; padding:0 20px; }

/* ---------- Cabeçalho ---------- */
.topbar{
  background: var(--azul);
  color:#fff;
}
.topbar .container{
  display:flex; align-items:center; justify-content:space-between;
  height:64px;
}
.logo{ display:flex; align-items:center; gap:10px; font-weight:800; font-size:20px; letter-spacing:.3px; }
.logo .dot{ width:30px; height:30px; border-radius:8px;
  background: var(--dourado); display:grid; place-items:center; color:var(--azul); font-weight:900; }
/* Logo em imagem (arquivo: imagem/logo.png). Trava de tamanho à prova de imagem grande. */
.logo{ max-width:200px; overflow:hidden; }
.logo img{ height:36px !important; width:auto !important; max-width:180px !important;
  object-fit:contain; display:block; }
@media (max-width:560px){ .logo img{ height:30px !important; } }
.nav-cta{
  background: var(--dourado); color: var(--azul);
  padding:9px 18px; border-radius:999px; font-weight:700; font-size:14px;
}
/* No celular, o cabeçalho empilha e centraliza */
@media (max-width:560px){
  .topbar .container{ flex-direction:column; height:auto; gap:10px; padding-top:12px; padding-bottom:12px; }
  .nav-cta{ font-size:13px; }
}

/* ---------- Faixa hero (tema Copa) ---------- */
.hero{
  background:
    radial-gradient(1200px 400px at 80% -10%, rgba(247,201,72,.25), transparent 60%),
    linear-gradient(135deg, var(--azul) 0%, var(--azul-claro) 60%, var(--verde-esc) 130%);
  color:#fff;
  position:relative;
  overflow:hidden;
}
/* Banner de imagem no hero (arquivo: imagem/banner.png) */
.hero-banner{
  background:
    linear-gradient(90deg, rgba(11,42,91,.55) 0%, rgba(11,42,91,.25) 40%, rgba(11,42,91,0) 70%),
    url('../imagem/banner.png') center top/cover no-repeat;
}
.hero::after{ /* listra dourada estilo faixa */
  content:""; position:absolute; left:0; right:0; bottom:0; height:6px;
  background: linear-gradient(90deg, var(--verde), var(--dourado), var(--verde));
}
.hero .container{ display:grid; grid-template-columns: 1.1fr .9fr; gap:30px;
  align-items:center; padding:54px 20px 64px; }
@media (max-width:840px){ .hero .container{ grid-template-columns:1fr; text-align:center; } }

/* Tarja de leitura atrás do texto, para o banner aparecer limpo atrás */
.hero-texto{
  background: rgba(8,30,66,.55);
  padding: 28px 30px;
  border-radius: 16px;
  backdrop-filter: blur(2px);
}
@media (max-width:840px){ .hero-texto{ background: rgba(8,30,66,.66); } }

.eyebrow{
  display:inline-block; background: rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.25);
  padding:6px 14px; border-radius:999px; font-size:13px; font-weight:600;
  margin-bottom:16px;
}
.hero h1{ font-size:42px; line-height:1.08; font-weight:900; margin-bottom:14px; }
.hero h1 .gold{ color: var(--dourado); }
.hero p.sub{ font-size:18px; color:#dfe6f5; max-width:520px; margin-bottom:26px; }
@media (max-width:840px){ .hero p.sub{ margin:0 auto 26px; } }

/* ---------- Ajustes do hero no MOBILE ---------- */
/* Tablet e telas médias: degradê cobre tudo (some o lado limpo,
   senão no retrato o texto fica sobre a imagem e atrapalha) */
@media (max-width:840px){
  .hero-banner{
    background:
      linear-gradient(180deg, rgba(11,42,91,.55) 0%, rgba(11,42,91,.78) 100%),
      url('../imagem/banner.png') center top/cover no-repeat;
  }
  .hero .container{ padding:40px 18px 48px; }
  .hero h1{ font-size:32px; }
  .hero p.sub{ font-size:16px; }
}
/* Celular: tipografia menor e tarja com menos respiro */
@media (max-width:560px){
  .hero .container{ padding:32px 14px 40px; }
  .hero h1{ font-size:26px; line-height:1.12; }
  .hero p.sub{ font-size:15px; margin-bottom:20px; }
  .hero-texto{ padding:20px 18px; border-radius:14px; }
  .eyebrow{ font-size:12px; }
  /* botão ocupa a largura toda, mais fácil de tocar */
  .hero .btn{ width:100%; justify-content:center; }
}

.btn{
  display:inline-flex; align-items:center; gap:8px;
  background: var(--dourado); color: var(--azul);
  font-weight:800; font-size:16px; padding:14px 26px; border-radius:999px;
  border:0; cursor:pointer; transition:transform .12s ease, filter .12s ease;
}
.btn:hover{ transform: translateY(-2px); filter:brightness(1.05); }
.btn.secundario{ background:#fff; }
.btn.verde{ background:var(--verde); color:#fff; }

/* Botão de ação perigosa (remover tudo) */
.btn-perigo{ display:inline-block; background:#fde8e8; color:#a02020;
  border:1px solid #f3c0c0; font-weight:700; font-size:13px;
  padding:9px 16px; border-radius:999px; cursor:pointer; transition:background .12s ease; }
.btn-perigo:hover{ background:#f9d5d5; }
@media (max-width:680px){
  .painel form > div[style*="repeat(5"]{ grid-template-columns:repeat(2,1fr) !important; }
}

/* ---------- Cartão dos prêmios ---------- */
.premios{
  background:#fff; border-radius:18px; padding:22px;
  box-shadow: var(--sombra); color:#1a1f2b;
}
.premios h3{ font-size:14px; text-transform:uppercase; letter-spacing:.6px;
  color:var(--cinza-tx); margin-bottom:14px; }
.premio-item{ display:flex; align-items:center; gap:14px; padding:12px 0; }
.premio-item + .premio-item{ border-top:1px dashed var(--borda); }
.premio-emoji{ width:54px; height:54px; border-radius:12px; flex:none;
  display:grid; place-items:center; font-size:28px;
  background: var(--cinza-bg); }
.premio-item b{ display:block; font-size:17px; }
.premio-item span{ font-size:13px; color:var(--cinza-tx); }

/* ---------- Como funciona ---------- */
.section{ padding:56px 0; }
.section h2{ font-size:28px; font-weight:800; text-align:center; margin-bottom:8px; color:var(--azul); }
.section .lead{ text-align:center; color:var(--cinza-tx); margin-bottom:36px; }
.passos{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media (max-width:760px){ .passos{ grid-template-columns:1fr; } }
.passo{ background:#fff; border:1px solid var(--borda); border-radius:var(--radius);
  padding:24px; text-align:center; }
.passo .num{ width:40px; height:40px; border-radius:50%; margin:0 auto 14px;
  background:var(--azul); color:#fff; font-weight:800; display:grid; place-items:center; }
.passo h4{ font-size:18px; margin-bottom:6px; }
.passo p{ font-size:14px; color:var(--cinza-tx); }
@media (max-width:560px){ .section{ padding:40px 0; } .section h2{ font-size:24px; } }

/* ---------- Faixa CTA final ---------- */
.cta-faixa{ background:var(--verde); color:#fff; text-align:center; padding:46px 20px; }
.cta-faixa h2{ font-size:26px; margin-bottom:8px; }
.cta-faixa p{ opacity:.9; margin-bottom:22px; }
@media (max-width:560px){ .cta-faixa h2{ font-size:22px; } .cta-faixa .btn{ width:100%; justify-content:center; } }

/* ---------- Formulários / páginas internas ---------- */
.painel{
  max-width:560px; margin:48px auto; background:#fff;
  border-radius:var(--radius); box-shadow:var(--sombra); padding:34px;
}
@media (max-width:560px){ .painel{ margin:24px 14px; padding:24px 20px; } }
.painel h1{ font-size:26px; color:var(--azul); margin-bottom:6px; }
.painel .desc{ color:var(--cinza-tx); margin-bottom:24px; font-size:15px; }
.campo{ margin-bottom:18px; }
.campo label{ display:block; font-weight:600; font-size:14px; margin-bottom:6px; }
.campo input, .campo select, .campo textarea{
  width:100%; padding:13px 14px; border:1px solid var(--borda);
  border-radius:10px; font-size:16px; background:#fff; font-family:inherit;
}
.campo textarea{ resize:vertical; line-height:1.5; }
.campo input:focus, .campo select:focus, .campo textarea:focus{ outline:none; border-color:var(--azul-claro);
  box-shadow:0 0 0 3px rgba(21,68,143,.15); }
/* ---------- Checkout ---------- */
.checkout{ display:grid; grid-template-columns:1.4fr 1fr; gap:24px; align-items:start; }
@media (max-width:840px){ .checkout{ grid-template-columns:1fr; } }
.resumo-linha{ display:flex; justify-content:space-between; align-items:baseline;
  gap:12px; padding:10px 0; font-size:15px; }
.resumo-linha span{ color:var(--cinza-tx); }
.resumo-linha strong{ text-align:right; }
.resumo-hr{ border:0; border-top:1px dashed var(--borda); margin:8px 0; }
.resumo-linha.total{ font-size:18px; }
.resumo-linha.total strong{ color:var(--verde-esc); }
.resumo-linha small{ font-size:12px; color:var(--cinza-tx); }

/* ---------- Modal de pagamento ---------- */
.modal-fundo{ display:none; position:fixed; inset:0; z-index:50;
  background:rgba(8,18,40,.45);
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  padding:20px; }
.modal-fundo.aberto{ display:flex; align-items:center; justify-content:center;
  animation:modal-fade .18s ease; }
@keyframes modal-fade{ from{ opacity:0; } to{ opacity:1; } }

.modal-caixa{ position:relative; background:#fff; border-radius:20px;
  width:100%; max-width:420px; padding:30px;
  box-shadow:0 24px 70px rgba(8,18,40,.45);
  animation:modal-pop .22s cubic-bezier(.2,.8,.3,1); }
@keyframes modal-pop{ from{ opacity:0; transform:translateY(14px) scale(.97); }
  to{ opacity:1; transform:translateY(0) scale(1); } }

.modal-x{ position:absolute; top:16px; right:18px; width:32px; height:32px;
  border:0; background:var(--cinza-bg); border-radius:50%;
  font-size:20px; line-height:1; color:var(--cinza-tx); cursor:pointer;
  display:grid; place-items:center; transition:background .12s ease; }
.modal-x:hover{ background:#e2e6ef; }
.modal-titulo{ font-size:21px; color:var(--azul); margin-bottom:4px; padding-right:30px; }
.modal-sub{ color:var(--cinza-tx); font-size:14px; margin-bottom:22px; }
.modal-sub strong{ color:var(--verde-esc); }

.opcao-pgto{ display:flex; align-items:center; gap:14px; width:100%;
  text-align:left; background:#fff; border:2px solid var(--borda); border-radius:14px;
  padding:16px 18px; margin-bottom:12px; cursor:pointer;
  transition:border-color .12s ease, background .12s ease, transform .08s ease; }
.opcao-pgto:hover{ border-color:var(--verde); background:#f7fbf8; }
.opcao-pgto:active{ transform:scale(.99); }
.opcao-icone{ font-size:26px; flex:none; width:44px; height:44px; border-radius:12px;
  background:var(--cinza-bg); display:grid; place-items:center; }
.opcao-txt{ flex:1; display:flex; flex-direction:column; }
.opcao-txt strong{ font-size:16px; color:var(--azul); }
.opcao-txt small{ font-size:13px; color:var(--cinza-tx); }
.opcao-seta{ font-size:20px; color:var(--verde); }
.opcao-tag{ font-size:12px; font-weight:700; color:var(--cinza-tx);
  background:var(--cinza-bg); padding:4px 10px; border-radius:999px; }

.opcao-pgto.desabilitada{ opacity:.5; cursor:not-allowed; }
.opcao-pgto.desabilitada:hover{ border-color:var(--borda); background:#fff; }
.opcao-pgto.desabilitada:active{ transform:none; }

/* ---------- Página da camisa: estilo loja ---------- */
.produto{ display:grid; grid-template-columns:1fr 1fr; gap:36px; align-items:start;
  background:#fff; border-radius:var(--radius); box-shadow:var(--sombra); padding:28px; }
@media (max-width:840px){ .produto{ grid-template-columns:1fr; gap:24px; padding:18px; } }

/* Galeria: palco com foto grande deslizante */
.galeria-loja{ width:100%; }
.palco{ position:relative; overflow:hidden; border-radius:14px;
  border:1px solid var(--borda); background:var(--cinza-bg); }
.trilho{ display:flex; transition:transform .3s ease; }
.trilho .slide{ min-width:100%; width:100%; aspect-ratio:1/1; object-fit:cover; display:block; }
.seta{ position:absolute; top:50%; transform:translateY(-50%);
  width:40px; height:40px; border-radius:50%; border:0; cursor:pointer;
  background:rgba(11,42,91,.78); color:#fff; font-size:24px; line-height:1;
  display:grid; place-items:center; z-index:2; transition:background .12s ease; }
.seta:hover{ background:var(--azul); }
.seta-esq{ left:10px; } .seta-dir{ right:10px; }

/* Ficha (lado direito) */
.eyebrow-loja{ display:inline-block; background:var(--cinza-bg); color:var(--azul);
  font-weight:700; font-size:13px; padding:6px 14px; border-radius:999px; margin-bottom:12px; }
.ficha h1{ font-size:26px; color:var(--azul); margin-bottom:8px; }
.ficha-sub{ color:var(--cinza-tx); font-size:15px; margin-bottom:22px; }

.campo small{ color:var(--cinza-tx); font-size:12px; }

/* ---------- Caixas de resultado ---------- */
.resultado{ max-width:560px; margin:48px auto; }
@media (max-width:560px){ .resultado{ margin:24px 14px; } }
.card-res{ background:#fff; border-radius:var(--radius); box-shadow:var(--sombra);
  padding:38px; text-align:center; }
@media (max-width:560px){ .card-res{ padding:28px 20px; } }
.card-res .icone{ font-size:56px; margin-bottom:12px; }
.card-res.ganhou{ border-top:6px solid var(--verde); }
.card-res.perdeu{ border-top:6px solid #c0c6d4; }
.card-res h1{ font-size:28px; margin-bottom:8px; }
.card-res.ganhou h1{ color:var(--verde-esc); }
.card-res .premio-tag{ display:inline-block; background:var(--dourado);
  color:var(--azul); font-weight:800; padding:8px 18px; border-radius:999px;
  margin:10px 0 18px; }

/* ---------- Tabela admin ---------- */
.adminbar{ background:var(--azul); color:#fff; padding:14px 0; }
.adminbar .container{ display:flex; justify-content:space-between; align-items:center; gap:10px; }
@media (max-width:560px){ .adminbar .container{ flex-direction:column; text-align:center; } }
/* No celular a tabela rola na horizontal em vez de espremer */
.tabela-wrap{ width:100%; overflow-x:auto; }
.tabela{ width:100%; border-collapse:collapse; background:#fff;
  border-radius:var(--radius); overflow:hidden; box-shadow:var(--sombra); min-width:560px; }
.tabela th, .tabela td{ padding:12px 14px; text-align:left; font-size:14px;
  border-bottom:1px solid var(--borda); }
.tabela th{ background:var(--cinza-bg); font-weight:700; color:var(--azul); }
.badge{ font-size:12px; font-weight:700; padding:3px 10px; border-radius:999px; }
.badge.sim{ background:#e3f6ec; color:var(--verde-esc); }
.badge.nao{ background:#f0f1f5; color:var(--cinza-tx); }

.flash{ padding:12px 16px; border-radius:10px; margin-bottom:18px; font-size:14px; }
.flash.ok{ background:#e3f6ec; color:var(--verde-esc); }
.flash.erro{ background:#fde8e8; color:#a02020; }

/* ---------- Rodapé ---------- */
footer{ background:var(--azul); color:#aab6d0; padding:30px 0; font-size:13px; text-align:center; }
footer .container{ display:flex; flex-direction:column; gap:6px; }
.aviso-legal{ font-size:11px; opacity:.7; max-width:760px; margin:0 auto; }

/* Spinner para loading do cartão */
.spinner {
  width: 50px;
  height: 50px;
  border: 4px solid #e2e8f0;
  border-top-color: #10b981;
  border-radius: 50%;
  margin: 0 auto;
  animation: girar 0.8s linear infinite;
}

@keyframes girar {
  to { transform: rotate(360deg); }
}

/* Formulário do cartão */
.cartao-form {
  background: #f8fafc;
  padding: 16px;
  border-radius: 16px;
  margin-top: 8px;
}

.cartao-row {
  display: flex;
  gap: 12px;
}

.cartao-row .campo {
  flex: 1;
}