/* BOLÃO COPA 2026 — style.css v9 */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Inter:wght@400;500;600;700&display=swap');

:root {
  --verde:      #006633; --verde-md:   #00883F; --verde-bg:  #E8F5EE;
  --dourado:    #C9A227; --dourado-lt: #F0C040;
  --branco:     #FFFFFF; --cinza-lt:   #F4F6F8; --cinza-md:  #E0E5EA; --cinza: #9CA3AF;
  --texto:      #1A1F2E; --texto-md:   #4B5563; --vermelho:  #DC2626;
  --radius:     10px;    --radius-lg:  16px;
  --shadow:     0 2px 10px rgba(0,0,0,.07);
  --shadow-lg:  0 6px 24px rgba(0,0,0,.11);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:'Inter',sans-serif;background:var(--cinza-lt);color:var(--texto);min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased}

/* ── Hero ────────────────────────────────────────────────── */
.hero{background:linear-gradient(135deg,#006633 0%,#004d26 55%,#002d15 100%);color:#fff;padding:24px 16px 20px;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 20% 50%,rgba(201,162,39,.12) 0%,transparent 50%),radial-gradient(circle at 80% 30%,rgba(0,136,63,.2) 0%,transparent 50%)}
.hero-content{position:relative;z-index:1;max-width:700px;margin:0 auto}
.hero-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(28px,9vw,56px);letter-spacing:2px;line-height:1;margin-bottom:6px}
.hero-title .gold{color:#F0C040}
.hero-sub{color:rgba(255,255,255,.75);font-size:13px;margin-bottom:16px}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid rgba(255,255,255,.15);border-radius:12px;overflow:hidden;background:rgba(0,0,0,.15)}
.hero-stat{padding:12px 6px;border-right:1px solid rgba(255,255,255,.12)}
.hero-stat:last-child{border-right:none}
.hero-stat-val{font-family:'Bebas Neue',sans-serif;font-size:24px;color:#F0C040;line-height:1}
.hero-stat-lbl{font-size:9px;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.8px;margin-top:2px}

/* ── Boas-vindas ─────────────────────────────────────────── */
.bv-card{background:#EFF6FF;border:1.5px solid #BFDBFE;border-radius:var(--radius-lg);padding:16px;margin-bottom:16px}
.bv-card.bv-card-warn{background:#FFFBEB;border-color:#FDE68A}
.bv-top{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px}
.bv-emoji{font-size:26px;flex-shrink:0;line-height:1}
.bv-msg{flex:1}
.bv-titulo{font-weight:700;font-size:15px;color:#1E40AF;margin-bottom:3px}
.bv-card-warn .bv-titulo{color:#92400E}
.bv-sub{font-size:13px;color:#3B82F6;line-height:1.4}
.bv-card-warn .bv-sub{color:#B45309}
.bv-btns{display:flex;gap:8px}
.bv-btns .btn{flex:1}

/* ── Busca ───────────────────────────────────────────────── */
.busca-wrap{margin-bottom:10px}
.busca-box{display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--cinza-md);border-radius:var(--radius-lg);padding:11px 14px;transition:border-color .15s,box-shadow .15s;box-shadow:var(--shadow)}
.busca-box:focus-within{border-color:var(--verde);box-shadow:0 0 0 3px rgba(0,102,51,.08)}
.busca-icon{font-size:16px;flex-shrink:0;color:var(--cinza)}
.busca-box input{flex:1;border:none;background:none;font-family:'Inter',sans-serif;font-size:14px;color:var(--texto);outline:none;min-width:0}
.busca-box input::placeholder{color:var(--cinza)}
.busca-clear{display:none;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--cinza);border:none;color:#fff;font-size:10px;cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent}

/* ── Pills de status ─────────────────────────────────────── */
.status-pills{display:flex;gap:8px;margin-bottom:6px;flex-wrap:wrap}
.spill{display:inline-flex;align-items:center;padding:8px 20px;border-radius:20px;border:1.5px solid var(--cinza-md);background:var(--cinza-lt);color:var(--cinza);font-family:'Inter',sans-serif;font-size:13px;font-weight:600;white-space:nowrap;cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}
.spill:hover{border-color:var(--verde);color:var(--verde);background:var(--verde-bg)}
.spill.active{background:var(--verde);border-color:var(--verde);color:#fff}

/* Contador global */
.filtro-contador{font-size:11px;color:var(--cinza);margin-bottom:16px;min-height:18px}

/* ── Cabeçalho de fase ───────────────────────────────────── */
.fase-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.fase-header-left{flex:1;min-width:0}
.fase-header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* Botão seletor de grupo */
.grupo-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;border-radius:20px;
  border:1.5px solid var(--cinza-md);
  background:#fff;color:var(--texto-md);
  font-family:'Inter',sans-serif;font-size:12px;font-weight:600;
  cursor:pointer;white-space:nowrap;
  transition:all .15s;
  -webkit-tap-highlight-color:transparent;
  box-shadow:var(--shadow);
}
.grupo-btn:hover,.grupo-btn:active{border-color:var(--verde);color:var(--verde)}
.grupo-btn.ativo{background:var(--verde);border-color:var(--verde);color:#fff}
.grupo-btn-label{pointer-events:none}
.grupo-btn-arrow{font-size:9px;opacity:.55;pointer-events:none;margin-left:1px}

/* Contador da fase */
.fase-contador{font-size:12px;font-weight:600;color:var(--cinza);white-space:nowrap}

/* ── MODAL DE GRUPO ─────────────────────────────────────── */
/* Usa visibility+opacity para permitir transição CSS no mobile */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:500;display:none}
.modal-overlay.open{display:block}
.modal-grupo{position:fixed;bottom:0;left:0;right:0;background:#fff;border-radius:20px 20px 0 0;z-index:501;padding:20px 16px 32px;box-shadow:0 -8px 32px rgba(0,0,0,.18);display:none;max-height:80vh;overflow-y:auto}
.modal-grupo.open{display:block}

.modal-grupo-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:18px;
}
.modal-grupo-titulo{
  font-family:'Bebas Neue',sans-serif;
  font-size:20px;color:var(--verde);letter-spacing:.5px;
}
.modal-grupo-close{
  background:var(--cinza-lt);border:none;
  width:34px;height:34px;border-radius:50%;
  font-size:14px;cursor:pointer;color:var(--texto-md);
  display:flex;align-items:center;justify-content:center;
  -webkit-tap-highlight-color:transparent;
}

/* Grid de opções no modal */
.modal-grupo-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:8px;
}

/* Pill do modal */
.mgp{
  padding:13px 6px;
  border-radius:10px;
  border:1.5px solid var(--cinza-md);
  background:#fff;color:var(--texto-md);
  font-family:'Inter',sans-serif;font-size:14px;font-weight:700;
  cursor:pointer;text-align:center;
  transition:all .15s;
  -webkit-tap-highlight-color:transparent;
  line-height:1;
}
.mgp:active{transform:scale(.95)}
.mgp.mgp-active{background:var(--verde);border-color:var(--verde);color:#fff}

/* "Todos" ocupa linha inteira */
.mgp-todos{
  grid-column:1/-1;
  background:var(--cinza-lt);
  border-color:transparent;
  color:var(--texto-md);
  font-size:13px;
  padding:11px;
}
.mgp-todos.mgp-active{background:var(--verde);border-color:var(--verde);color:#fff}

/* ── Layout ──────────────────────────────────────────────── */
.page{max-width:1100px;margin:0 auto;padding:20px 14px 60px}
.page-sm{max-width:480px;margin:0 auto;padding:32px 14px 60px}
.page-md{max-width:720px;margin:0 auto;padding:20px 14px 60px}

/* ── Cards ───────────────────────────────────────────────── */
.card{background:#fff;border-radius:var(--radius-lg);border:1.5px solid var(--cinza-md);box-shadow:var(--shadow);padding:20px}
.card-sm{padding:16px}
.card-title{font-family:'Bebas Neue',sans-serif;font-size:19px;letter-spacing:.5px;color:var(--verde);margin-bottom:14px}

/* ── Jogo card ───────────────────────────────────────────── */
.jogo-card{background:#fff;border-radius:var(--radius-lg);border:1.5px solid var(--cinza-md);box-shadow:var(--shadow);overflow:hidden;transition:transform .15s,box-shadow .15s}
.jogo-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.jogo-card.hidden{display:none!important}
.jogo-header{background:linear-gradient(135deg,var(--verde) 0%,var(--verde-md) 100%);color:#fff;padding:8px 14px;display:flex;justify-content:space-between;align-items:center;font-size:11px;gap:8px}
.jogo-fase{font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.jogo-data{color:rgba(255,255,255,.85);white-space:nowrap}
.jogo-body{padding:16px 14px 12px}
.jogo-placar{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:12px}
.jogo-time{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;min-width:0}
.jogo-bandeira{font-size:30px;line-height:1}
.jogo-time-nome{font-size:12px;font-weight:700;text-align:center;color:var(--texto);line-height:1.2;word-break:break-word}
.jogo-vs{font-family:'Bebas Neue',sans-serif;font-size:18px;color:var(--cinza);flex-shrink:0;padding:0 4px}
.jogo-resultado{font-family:'Bebas Neue',sans-serif;font-size:24px;color:var(--verde);letter-spacing:2px;flex-shrink:0}
.jogo-footer{border-top:1px solid var(--cinza-md);padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.jogo-premio{font-size:12px;font-weight:700;color:var(--dourado)}
.jogo-premio small{font-weight:400;color:var(--cinza);font-size:10px;display:block}
.grid-jogos{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;margin-bottom:28px}

/* ── Section ─────────────────────────────────────────────── */
.section-title{font-family:'Bebas Neue',sans-serif;font-size:22px;color:var(--verde);letter-spacing:.5px;margin-bottom:1px}
.section-sub{font-size:13px;color:var(--cinza);margin-bottom:0}

/* ── Badges ──────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.badge-aberto{background:#DCFCE7;color:#166534}
.badge-fechado{background:#FEF3C7;color:#92400E}
.badge-encerrado{background:#F3F4F6;color:#6B7280}
.badge-acertou{background:#DCFCE7;color:#166534}
.badge-errou{background:#FEE2E2;color:#991B1B}
.badge-pendente{background:#FEF3C7;color:#92400E}
.badge-pago{background:#DCFCE7;color:#166534}

/* ── Botões ──────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:10px 18px;border-radius:8px;font-family:'Inter',sans-serif;font-size:13px;font-weight:600;border:none;cursor:pointer;text-decoration:none;transition:all .15s;white-space:nowrap;-webkit-tap-highlight-color:transparent}
.btn-primary{background:var(--verde);color:#fff}
.btn-primary:hover{background:var(--verde-md)}
.btn-gold{background:var(--dourado);color:#fff}
.btn-gold:hover{background:#F0C040;color:var(--texto)}
.btn-outline{background:transparent;border:1.5px solid var(--cinza-md);color:var(--texto-md)}
.btn-outline:hover{border-color:var(--verde);color:var(--verde)}
.btn-danger{background:var(--vermelho);color:#fff}
.btn-sm{padding:5px 14px;font-size:12px}
.btn-full{width:100%}
.btn:disabled{opacity:.45;cursor:not-allowed}

/* ── Forms ───────────────────────────────────────────────── */
.form-group{margin-bottom:14px}
.form-label{display:block;font-size:13px;font-weight:600;color:var(--texto-md);margin-bottom:5px}
.form-control{width:100%;padding:10px 13px;border:1.5px solid var(--cinza-md);border-radius:8px;font-family:'Inter',sans-serif;font-size:14px;color:var(--texto);background:#fff;transition:border-color .15s;outline:none;-webkit-appearance:none;appearance:none}
.form-control:focus{border-color:var(--verde)}
.form-hint{font-size:11px;color:var(--cinza);margin-top:4px}
.score-input{width:48px;height:42px;text-align:center;font-family:'Bebas Neue',sans-serif;font-size:22px;border:2px solid var(--cinza-md);border-radius:8px;background:#fff;color:var(--verde);outline:none;-moz-appearance:textfield;-webkit-appearance:none}
.score-input::-webkit-inner-spin-button,.score-input::-webkit-outer-spin-button{-webkit-appearance:none}
.score-input:focus{border-color:var(--verde)}
.score-sep{font-family:'Bebas Neue',sans-serif;font-size:18px;color:var(--cinza)}
.palpite-row{display:flex;align-items:center;gap:8px;background:var(--cinza-lt);border-radius:10px;padding:10px 12px;margin-bottom:8px}
.palpite-row .time-label{font-size:12px;font-weight:700;flex:1;text-align:right}
.palpite-row .time-label-b{text-align:left}

/* ── Alerts ──────────────────────────────────────────────── */
.alert{padding:11px 14px;border-radius:8px;font-size:13px;margin-bottom:14px;display:block;line-height:1.5}
.alert-success{background:#DCFCE7;color:#166534;border:1px solid #BBF7D0}
.alert-danger{background:#FEE2E2;color:#991B1B;border:1px solid #FECACA}
.alert-warning{background:#FEF3C7;color:#92400E;border:1px solid #FDE68A}
.alert-info{background:#DBEAFE;color:#1E40AF;border:1px solid #BFDBFE}

/* ── Tabelas ─────────────────────────────────────────────── */
.table-wrap{overflow-x:auto;border-radius:var(--radius);-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{background:var(--verde);color:#fff;padding:9px 12px;text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.4px}
thead th:first-child{border-radius:10px 0 0 0}
thead th:last-child{border-radius:0 10px 0 0}
tbody tr{border-bottom:1px solid var(--cinza-md)}
tbody tr:hover{background:var(--cinza-lt)}
tbody td{padding:9px 12px;color:var(--texto-md)}
tbody td strong{color:var(--texto)}

/* ── Grids ───────────────────────────────────────────────── */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}

/* ── Saldo card ──────────────────────────────────────────── */
.saldo-card{background:linear-gradient(135deg,var(--verde) 0%,var(--verde-md) 100%);border-radius:var(--radius-lg);color:#fff;padding:24px;text-align:center}
.saldo-valor{font-family:'Bebas Neue',sans-serif;font-size:48px;letter-spacing:1px;color:#F0C040;line-height:1}
.saldo-label{font-size:12px;color:rgba(255,255,255,.7);margin-top:4px}

/* ── Auth ────────────────────────────────────────────────── */
.auth-logo{text-align:center;margin-bottom:24px}
.auth-logo-title{font-family:'Bebas Neue',sans-serif;font-size:32px;color:var(--verde);letter-spacing:2px}
.auth-logo-title span{color:var(--dourado)}
.divider{display:flex;align-items:center;gap:10px;color:var(--cinza);font-size:11px;margin:14px 0}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--cinza-md)}

/* ── Misc ────────────────────────────────────────────────── */
.rank-1 td:first-child{color:var(--dourado);font-size:16px}
.rank-2 td:first-child{color:var(--cinza);font-size:14px}
.rank-3 td:first-child{color:#CD7F32;font-size:14px}
.spinner{width:32px;height:32px;border:3px solid var(--cinza-md);border-top-color:var(--verde);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto}
@keyframes spin{to{transform:rotate(360deg)}}
.empty-state{text-align:center;padding:50px 20px;color:var(--cinza)}
.empty-state-icon{font-size:44px;margin-bottom:10px}
.empty-state-title{font-size:16px;font-weight:600;color:var(--texto-md);margin-bottom:4px}

/* ── Admin ───────────────────────────────────────────────── */
.admin-wrap{display:flex;min-height:100vh}
.admin-sidebar{width:220px;flex-shrink:0;background:var(--verde);padding:20px 0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.admin-sidebar-logo{font-family:'Bebas Neue',sans-serif;font-size:18px;color:#fff;padding:0 20px 20px;border-bottom:1px solid rgba(255,255,255,.15);margin-bottom:12px;letter-spacing:1px}
.admin-sidebar-logo span{color:#F0C040}
.admin-nav a{display:flex;align-items:center;gap:8px;padding:10px 20px;color:rgba(255,255,255,.8);text-decoration:none;font-size:14px;font-weight:500;transition:background .15s,color .15s}
.admin-nav a:hover,.admin-nav a.active{background:rgba(255,255,255,.12);color:#fff}
.admin-nav .section-label{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.4);padding:12px 20px 4px}
.admin-main{flex:1;padding:28px 32px;overflow-x:auto}
.admin-page-title{font-family:'Bebas Neue',sans-serif;font-size:28px;color:var(--verde);letter-spacing:.5px;margin-bottom:20px}

/* ═══════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════ */
@media(max-width:640px){
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .hero-stat{border-right:none!important;border-bottom:1px solid rgba(255,255,255,.12)}
  .hero-stat:nth-child(odd){border-right:1px solid rgba(255,255,255,.12)!important}
  .hero-stat:nth-child(3),.hero-stat:nth-child(4){border-bottom:none}
  .hero-stat-val{font-size:22px}
  .hero{padding:18px 14px 16px}
  .bv-btns{flex-direction:column}
  .grid-jogos{grid-template-columns:1fr;gap:10px}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .page,.page-sm,.page-md{padding:14px 12px 60px}
  .card{padding:16px}
  .saldo-card{padding:20px}
  .saldo-valor{font-size:40px}
  .section-title{font-size:20px}
  .table-wrap{margin:0 -12px;border-radius:0}
  table{font-size:12px}
  thead th,tbody td{padding:7px 10px}
  .admin-sidebar{display:none}
  .admin-main{padding:16px}
}
@media(min-width:641px) and (max-width:960px){
  .grid-jogos{grid-template-columns:repeat(2,1fr)}
}
