@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Nunito:wght@400;600;700;800;900&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* ── Paleta clara e esportiva ── */
  --bg:        #f2f4f8;          /* fundo geral: cinza-azulado bem claro */
  --surface:   #ffffff;          /* cards e painéis: branco */
  --surface2:  #f7f8fc;          /* fundo de detalhe: quase branco */
  --border:    #e2e6ef;          /* bordas suaves */

  /* Cor principal: azul-marinho esportivo */
  --primary:     #1a3a6b;        /* texto escuro, botões primários */
  --primary-dim: #1a3a6b12;
  --primary-mid: #1a3a6b28;

  /* Destaque: laranja-âmbar vibrante — esporte, energia, sem parecer erro */
  --accent:      #f59e0b;        /* âmbar */
  --accent-dim:  #f59e0b15;
  --accent-mid:  #f59e0b35;
  --accent-dark: #d97706;

  /* Feedback positivo */
  --green:    #059669;
  --green-bg: #ecfdf5;
  --green-bd: #a7f3d0;

  /* Feedback negativo — apenas para erros reais */
  --red:    #dc2626;
  --red-bg: #fef2f2;
  --red-bd: #fecaca;

  /* Feedback neutro/pontos */
  --yellow:    #d97706;
  --yellow-bg: #fffbeb;
  --yellow-bd: #fde68a;

  /* Texto */
  --text:   #1e293b;    /* quase preto */
  --muted:  #64748b;    /* cinza médio */
  --faint:  #cbd5e1;    /* cinza claro */

  --radius:    14px;
  --radius-sm: 9px;

  --shadow-sm: 0 1px 3px #1a3a6b0d, 0 1px 2px #1a3a6b0a;
  --shadow:    0 4px 16px #1a3a6b12, 0 2px 6px #1a3a6b0a;
}

body{
  background: var(--bg);
  color: var(--text);
  font-family: 'Nunito', sans-serif;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

/* Textura sutil no fundo */
body::before{
  content:'';
  position:fixed;inset:0;
  background:
    radial-gradient(ellipse 80% 50% at 50% -10%, #dbeafe44 0%, transparent 70%),
    radial-gradient(ellipse 60% 40% at 90% 110%, #fde68a22 0%, transparent 70%);
  pointer-events:none;z-index:0;
}

.app{display:flex;justify-content:center;padding:1.5rem 1rem 5rem;min-height:100vh;position:relative;z-index:1}
.inner{width:100%;max-width:500px}

/* PAGE ANIM */
.page{animation:fadeUp .22s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── TYPOGRAPHY ── */
h1{font-family:'Bebas Neue',cursive;font-size:3.2rem;letter-spacing:4px;color:var(--primary)}
h1 span{color:var(--accent)}
h2{font-family:'Bebas Neue',cursive;font-size:2rem;letter-spacing:2px;color:var(--primary)}
h3{font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:.5rem}
.sub{color:var(--muted);font-size:.9rem}

/* ── LAYOUT ── */
.stack{display:flex;flex-direction:column}
.gap-xs{gap:.35rem} .gap-sm{gap:.7rem} .gap-md{gap:1.2rem} .gap-lg{gap:1.8rem}
.row{display:flex;gap:.6rem;align-items:flex-end}
.row .field{flex:1}
.w-full{width:100%}
.divider{border:none;border-top:1px solid var(--border)}

/* ── CARDS ── */
.card{
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--radius);padding:1.1rem 1.3rem;
  box-shadow:var(--shadow-sm);
}
.card-accent{border-color:var(--accent-mid);background:var(--accent-dim)}
.card-green{ border-color:var(--green-bd);background:var(--green-bg)}
.card-blue{  border-color:var(--primary-mid);background:var(--primary-dim)}

/* ── INPUTS ── */
input[type=text],input[type=tel],input[type=number],input[type=password],select{
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--radius-sm);color:var(--text);
  padding:.72rem 1rem;font-size:.95rem;font-family:'Nunito',sans-serif;
  outline:none;transition:border-color .2s,box-shadow .2s;width:100%;
  box-shadow:var(--shadow-sm);
}
input:focus,select:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-dim);
}
input[type=number]{width:68px;text-align:center;padding:.6rem .3rem;font-size:1.1rem;font-weight:900}

.field{display:flex;flex-direction:column;gap:.4rem}
.field>label{font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;font-weight:700}
.phone-wrap{position:relative}
.phone-wrap input{padding-left:2.4rem}
.phone-flag{position:absolute;left:.9rem;top:50%;transform:translateY(-50%);font-size:1rem;pointer-events:none}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
  border:none;border-radius:var(--radius-sm);font-family:'Nunito',sans-serif;
  font-weight:800;font-size:.95rem;cursor:pointer;transition:all .18s;
  padding:.78rem 1.4rem;text-decoration:none;
}
.btn:disabled{opacity:.4;cursor:default!important;transform:none!important;box-shadow:none!important}

/* Primário — azul-marinho */
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:not(:disabled):hover{background:#142d55;transform:translateY(-2px);box-shadow:0 6px 20px #1a3a6b30}

/* Destaque — âmbar */
.btn-gold{background:var(--accent);color:#fff}
.btn-gold:not(:disabled):hover{background:var(--accent-dark);transform:translateY(-2px);box-shadow:0 6px 20px #f59e0b30}

/* Ghost */
.btn-ghost{background:var(--surface);color:var(--primary);border:1.5px solid var(--border)}
.btn-ghost:not(:disabled):hover{border-color:var(--primary);background:var(--primary-dim)}

/* Verde */
.btn-green{background:var(--green-bg);color:var(--green);border:1.5px solid var(--green-bd)}
.btn-green:not(:disabled):hover{background:#d1fae5}

/* Perigo — apenas para deletar no admin */
.btn-red{background:var(--red-bg);color:var(--red);border:1.5px solid var(--red-bd)}
.btn-red:not(:disabled):hover{background:#fee2e2}

.btn-full{width:100%}
.btn-sm{padding:.4rem .85rem;font-size:.8rem}
.btn-icon{width:42px;height:42px;padding:0;flex-shrink:0;font-size:1.3rem}

/* Voltar */
.back{
  background:none;border:none;color:var(--muted);font-family:'Nunito',sans-serif;
  font-size:.88rem;cursor:pointer;display:inline-flex;align-items:center;gap:.3rem;
  padding:0;transition:color .15s;font-weight:700;
}
.back:hover{color:var(--primary)}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:.3rem;border-radius:20px;padding:.28rem .9rem;font-size:.78rem;font-weight:700}
.badge-gold{background:var(--accent-dim);color:var(--accent-dark);border:1px solid var(--accent-mid)}
.badge-blue{background:var(--primary-dim);color:var(--primary);border:1px solid var(--primary-mid)}
.badge-purple{background:#f3e8ff;color:#7c3aed;border:1px solid #ddd6fe}
.badge-green{background:var(--green-bg);color:var(--green);border:1px solid var(--green-bd)}

/* ── SPORT GRID ── */
.sport-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.sport-btn{
  background:var(--surface);border:1.5px solid var(--border);color:var(--muted);
  border-radius:var(--radius-sm);padding:.75rem;font-family:'Nunito',sans-serif;
  font-size:.88rem;font-weight:700;cursor:pointer;transition:all .18s;
  box-shadow:var(--shadow-sm);
}
.sport-btn:hover{border-color:var(--accent);color:var(--primary);background:#fffbeb}
.sport-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent-dark)}

/* ── GAME CHIP ── */
.game-chip{
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--radius-sm);padding:.55rem 1rem;
  display:flex;align-items:center;gap:.7rem;font-size:.88rem;
  box-shadow:var(--shadow-sm);
}
.game-num{
  background:var(--accent-dim);color:var(--accent-dark);font-weight:900;font-size:.7rem;
  border-radius:50%;width:22px;height:22px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.rm-btn{background:none;border:none;color:var(--faint);font-size:1.2rem;cursor:pointer;padding:0;transition:color .15s}
.rm-btn:hover{color:var(--red)}

/* ── BET ROWS ── */
.bet-row{
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--radius);padding:1rem 1.1rem;transition:border-color .2s,background .2s;
  box-shadow:var(--shadow-sm);
}
.bet-row.done{border-color:var(--green-bd);background:var(--green-bg)}
.bet-game-label{font-size:.7rem;color:var(--accent-dark);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:.8rem;font-weight:800}
.bet-teams{display:flex;align-items:center;gap:.8rem}
.bet-team{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.team-name{font-size:.82rem;font-weight:800;text-align:center;color:var(--primary);line-height:1.2}
.bet-x{color:var(--faint);font-weight:900;font-size:1rem;flex-shrink:0}

/* ── RANKING ── */
.rank-item{
  display:flex;align-items:center;gap:1rem;
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--radius);padding:.9rem 1.2rem;
  transition:all .2s;box-shadow:var(--shadow-sm);
}
.rank-item.pos-1{border-color:var(--accent-mid);background:var(--accent-dim);box-shadow:0 4px 16px #f59e0b18}
.rank-item.pos-2{border-color:#e2e8f0;background:#f8fafc}
.rank-item.pos-3{border-color:#fed7aa;background:#fff7ed}
.rank-item.is-me{box-shadow:0 0 0 2.5px var(--accent),var(--shadow)}
.rank-pos{font-size:1.4rem;width:34px;text-align:center}
.rank-name{flex:1;font-weight:800;font-size:1rem;color:var(--primary)}
.rank-info{font-size:.75rem;color:var(--muted);margin-top:.1rem}
.rank-pts{font-family:'Bebas Neue',cursive;font-size:1.5rem;color:var(--accent-dark);letter-spacing:1px}

/* ── PTS BADGES ── */
.pts{border-radius:6px;padding:.15rem .45rem;font-size:.72rem;font-weight:900}
.pts-3{background:var(--green-bg); color:var(--green);  border:1px solid var(--green-bd)}
.pts-1{background:var(--yellow-bg);color:var(--yellow); border:1px solid var(--yellow-bd)}
.pts-0{background:#f1f5f9;         color:var(--muted);  border:1px solid var(--faint)}
.pts-x{background:#f1f5f9;         color:var(--faint);  border:1px solid var(--border)}

/* ── RESULT DETAIL ── */
.result-detail{
  background:var(--surface2);border-radius:var(--radius-sm);
  padding:.85rem;border:1.5px solid var(--border);margin-bottom:.4rem;
}
.result-bet-row{display:flex;gap:.6rem;align-items:center;font-size:.8rem;color:var(--muted);padding:.22rem 0}
.result-bet-row span:first-child{flex:1;font-weight:700;color:var(--text)}

/* ── TOAST ── */
.toast{
  position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);
  background:var(--primary);color:#fff;
  border-radius:var(--radius);padding:.8rem 1.6rem;
  font-size:.9rem;font-weight:700;z-index:999;white-space:nowrap;
  box-shadow:0 8px 24px #1a3a6b30;
  animation:toastIn .3s ease,toastOut .3s ease 2.3s both;
}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
@keyframes toastOut{to{opacity:0;transform:translateX(-50%) translateY(10px)}}

/* ── LOADER ── */
.loader{display:flex;align-items:center;justify-content:center;gap:.5rem;color:var(--muted);padding:3rem;font-size:.9rem}
.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── MISC ── */
.warn{
  background:#fffbeb;color:#92400e;
  border:1.5px solid var(--yellow-bd);
  border-radius:var(--radius-sm);padding:.75rem 1rem;font-size:.88rem;
}
.empty{color:var(--faint);text-align:center;padding:2.5rem 1rem;font-size:.9rem}

/* Tabs */
.tab-bar{display:flex;gap:.4rem;background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:.3rem}
.tab{flex:1;padding:.5rem;border:none;background:none;color:var(--muted);font-family:'Nunito',sans-serif;font-size:.85rem;font-weight:700;border-radius:6px;cursor:pointer;transition:all .2s}
.tab.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm)}

/* Scrollbar */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--faint);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--muted)}
