/* ============================================================
   FIFA EDGE — Styles v2 (Phase 2 aditivo)
   Gerado a partir de home-v2-preview.html + jogos-v2-preview.html
   Sem :root / html / body / * para não conflitar com styles.css.
   ============================================================ */

/* ===== home-v2-preview.html ===== */
body::before{
  content:'';
  position:fixed; inset:0;
  pointer-events:none; z-index:0;
  background-image:
    linear-gradient(rgba(120,180,255,0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(120,180,255,0.07) 1px, transparent 1px);
  background-size:44px 44px, 44px 44px;
}

.app, .topbar, .content{position:relative; z-index:1;}

@keyframes pulse {
0%   { box-shadow: 0 0 0 0 rgba(241,90,90,0.5); }
70%  { box-shadow: 0 0 0 6px rgba(241,90,90,0); }
100% { box-shadow: 0 0 0 0 rgba(241,90,90,0); }
}
























.topbar{
  display:grid; grid-template-columns:auto 1fr auto;
  align-items:center; gap:20px;
  padding:12px 24px;
  background:rgba(7,16,30,0.85);
  border-bottom:1px solid var(--line-1);
  position:sticky; top:0; z-index:10;
  backdrop-filter:blur(10px);
}

.crumbs{display:flex; align-items:center; gap:8px; font:500 12px/1 var(--f-mono); color:var(--text-3);}

.crumbs .sep{color:var(--text-3); opacity:0.5;}

.crumbs .cur{color:var(--text-0);}

.search{position:relative; max-width:420px; width:100%; justify-self:center;}

.search input{
  width:100%; background:var(--bg-2);
  border:1px solid var(--line-1); border-radius:var(--r-md);
  color:var(--text-1);
  padding:8px 12px 8px 34px;
  font:500 12.5px/1 var(--f-ui);
  outline:none;
}

.search input:focus{border-color:var(--accent-bd);}

.search input::placeholder{color:var(--text-3);}

.search .si{position:absolute; left:11px; top:50%; transform:translateY(-50%); color:var(--text-3); width:14px; height:14px;}

.search .kbd{position:absolute; right:10px; top:50%; transform:translateY(-50%); font:500 10px/1 var(--f-mono); color:var(--text-3); background:var(--bg-3); padding:3px 6px; border-radius:3px; border:1px solid var(--line-1);}

.topbar-right{display:flex; align-items:center; gap:14px;}

.ticker{
  display:flex; align-items:center; gap:14px;
  padding:6px 14px;
  border:1px solid var(--line-1); border-radius:var(--r-md);
  background:var(--bg-2);
}

.tick{display:flex; flex-direction:column; gap:1px;}

.tick .lbl{font:600 9px/1 var(--f-mono); color:var(--text-3); letter-spacing:0.08em; text-transform:uppercase;}

.tick .val{font:700 12px/1 var(--f-mono); color:var(--text-0);}

.tick .val.win{color:var(--win);}

.tick .val.gold{color:var(--accent);}

.user-chip{
  display:flex; align-items:center; gap:8px;
  padding:5px 12px 5px 5px;
  border:1px solid var(--line-2); border-radius:999px;
  background:var(--bg-2);
  cursor:pointer;
}

.user-chip .av{
  width:24px; height:24px; border-radius:50%;
  background:linear-gradient(135deg, var(--accent), var(--accent-dim));
  display:grid; place-items:center;
  color:#06101e; font:600 10px/1 var(--f-mono);
}

.user-chip .nm{font:600 12px/1 var(--f-ui); color:var(--text-0);}

.user-chip .rl{font:500 10px/1 var(--f-mono); color:var(--text-3); text-transform:uppercase; margin-top:2px;}

.content{padding:20px 24px 60px; min-width:0; max-width:1600px;}

.kpis{
  display:grid; grid-template-columns:repeat(4, 1fr);
  gap:var(--gap-grid, 14px);
  margin-bottom:20px;
}

.kpi-tile{
  background:var(--bg-card);
  border:1px solid var(--line-2);
  border-radius:var(--r-lg);
  padding:var(--pad-card);
  position:relative; overflow:hidden;
  backdrop-filter:blur(6px);
}

.kpi-tile .lbl{
  font:600 10px/1 var(--f-mono); color:var(--text-3);
  letter-spacing:0.12em; text-transform:uppercase;
  margin-bottom:8px;
  display:flex; align-items:center; gap:6px;
}

.kpi-tile .lbl .pip{width:6px; height:6px; border-radius:50%; background:var(--accent);}

.kpi-tile .lbl.win .pip{background:var(--win);}

.kpi-tile .lbl.loss .pip{background:var(--loss);}

.kpi-tile .val{
  font:800 26px/1 var(--f-mono);
  color:var(--text-0);
  letter-spacing:-0.02em;
}

.kpi-tile .val .unit{font-size:13px; color:var(--text-3); margin-left:2px;}

.kpi-tile .delta{
  display:inline-flex; align-items:center; gap:3px;
  font:700 11px/1 var(--f-mono);
  margin-top:8px; padding:2px 8px; border-radius:999px;
}

.kpi-tile .delta.pos{color:var(--win); background:rgba(54,211,153,0.12); border:1px solid rgba(54,211,153,0.28);}

.kpi-tile .delta.neg{color:var(--loss); background:rgba(241,90,90,0.12); border:1px solid rgba(241,90,90,0.28);}

.match-section{
  display:flex; align-items:center; gap:8px;
  padding:12px 16px;
  font:600 13px/1 var(--f-ui); color:var(--text-0);
  letter-spacing:-0.005em;
  border-bottom:1px solid var(--line-1);
  background:var(--bg-1);
}

.match-section .bar{width:3px; height:14px; background:var(--accent); border-radius:2px;}

.match-section .badge{font:400 10px/1 var(--f-mono); color:var(--text-3); padding:2px 6px; background:var(--bg-2); border-radius:4px;}

.match-section--live{color:var(--loss);}

.match-section--live .bar{background:var(--loss);}

.match-section--live .badge{color:var(--loss); background:rgba(229, 90, 90, 0.10);}

.page-head{display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:18px; gap:20px;}

.page-title{font-size:22px; font-weight:600; letter-spacing:-0.015em; color:var(--text-0); margin:0;}

.page-sub{font:500 11px/1 var(--f-mono); color:var(--text-3); margin-top:6px; letter-spacing:0.04em; text-transform:uppercase;}

.card{
  background:var(--bg-card);
  border:1px solid var(--line-2);
  border-radius:var(--r-lg);
  overflow:hidden;
  backdrop-filter:blur(6px);
  margin-bottom:18px;
}

.card-head{display:flex; align-items:center; justify-content:space-between; padding:12px 16px; border-bottom:1px solid var(--line-1);}

.card-title{display:flex; align-items:center; gap:8px; font:600 13px/1 var(--f-ui); color:var(--text-0); letter-spacing:-0.005em;}

.card-title .bar{width:3px; height:14px; background:var(--accent); border-radius:2px;}

.card-title .badge{font:400 10px/1 var(--f-mono); color:var(--text-3); padding:2px 6px; background:var(--bg-2); border-radius:3px; margin-left:4px;}

.card-title .badge.live{background:rgba(241,90,90,0.12); color:var(--loss); border:1px solid rgba(241,90,90,0.32);}

.card-body{padding:var(--pad-card);}

.card-body.flush{padding:0;}

.see-all{font:600 11px/1 var(--f-mono); color:var(--accent); text-decoration:none; padding:6px 10px; border-radius:var(--r-sm); border:1px solid var(--accent-bd); background:var(--accent-bg); letter-spacing:0.06em; text-transform:uppercase;}

.see-all:hover{background:rgba(245,185,66,0.18);}

.banners-wrap{position:relative; margin-bottom:18px;}

.banners-row{
  display:flex; gap:12px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scrollbar-width:none;
  padding:2px 2px 6px;
}

.banners-row::-webkit-scrollbar{display:none;}

.banners-arrow{
  position:absolute; top:50%; transform:translateY(-50%);
  width:36px; height:36px;
  border-radius:50%;
  background:rgba(7,16,30,0.85);
  border:1px solid var(--line-2);
  color:var(--text-0);
  font:600 18px/1 var(--f-ui);
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  z-index:2;
  backdrop-filter:blur(8px);
  transition:.15s ease;
}

.banners-arrow:hover{background:var(--accent-bg); color:var(--accent); border-color:var(--accent-bd);}

.banners-arrow.prev{left:-12px;}

.banners-arrow.next{right:-12px;}

.banners-dots{
  display:flex; justify-content:center; gap:6px;
  margin-top:10px;
}

.banners-dots span{
  width:6px; height:6px; border-radius:50%;
  background:var(--line-2);
  cursor:pointer; transition:.15s ease;
}

.banners-dots span.active{
  width:20px; border-radius:3px;
  background:var(--accent);
}

.banner-card{
  flex:0 0 calc((100% - 24px) / 3);
  scroll-snap-align:start;
  position:relative; height:128px;
  border-radius:var(--r-lg); border:1px solid var(--line-2);
  overflow:hidden; cursor:pointer;
  padding:16px 18px;
  display:flex; flex-direction:column; justify-content:space-between;
  backdrop-filter:blur(6px);
}

.banner-card.image{padding:0; background:var(--bg-2);}

.banner-card.image img{width:100%; height:100%; object-fit:cover; display:block;}

@media (max-width:768px){
.banner-card{
  flex: 0 0 100%;
  scroll-snap-align: center;
  max-width: 100%;
}
}

.banner-card.gold{
  background:radial-gradient(circle at 85% 30%, rgba(245,185,66,0.42), transparent 55%), linear-gradient(135deg, #1f1404 0%, #3a2608 100%);
  border-color:var(--brand-gold-bd);
}

.banner-card.blue{
  background:radial-gradient(circle at 85% 30%, rgba(44,107,255,0.42), transparent 55%), linear-gradient(135deg, #0a1228 0%, #1a2855 100%);
  border-color:var(--brand-blue-bd);
}

.banner-card.dark{
  background:linear-gradient(135deg, var(--bg-2) 0%, var(--bg-3) 100%);
  border-color:rgba(54,211,153,0.32);
}

.banner-card.dark .bg-img{object-position:right center;}

.banner-card.dark::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(7,16,30,0.85) 0%, rgba(7,16,30,0.45) 45%, rgba(7,16,30,0.05) 100%);
  z-index:1; pointer-events:none;
}

.banner-card.dark .h{text-shadow:0 2px 8px rgba(0,0,0,0.6);}

.banner-card.dark .sub{text-shadow:0 1px 4px rgba(0,0,0,0.6);}

a.banner-card, a.banner-card:link, a.banner-card:visited, a.banner-card:hover, a.banner-card:active{
  text-decoration:none !important;
  color:inherit !important;
}

.banner-card .h{font:800 18px/1.15 var(--f-ui); letter-spacing:-0.012em; color:#fff !important; text-shadow:0 2px 6px rgba(0,0,0,0.45);}

.banner-card .sub{font:600 12.5px/1.35 var(--f-ui); color:rgba(255,255,255,0.92) !important; max-width:82%; text-shadow:0 1px 4px rgba(0,0,0,0.5);}

.banner-card .cta{font:800 11px/1 var(--f-ui); letter-spacing:0.06em; text-transform:uppercase; padding:8px 14px; border-radius:var(--r-sm); background:var(--accent); color:#1a0f00; display:inline-block; align-self:flex-start; border:0; cursor:pointer; box-shadow:0 4px 12px rgba(0,0,0,0.35);}

.banner-card.blue .cta{background:var(--brand-blue-2); color:#fff;}

.banner-card.dark .cta{background:var(--win); color:#003120;}

.banner-card.whats .cta{background:#25D366; color:#003120;}

.banner-card.amber .cta{background:#ff9a42; color:#321800;}

.banner-card.violet .cta{background:var(--accent); color:#1a0f00;}

.banner-card.teal .cta{background:var(--accent); color:#1a0f00;}

.banner-card.crimson .cta{background:var(--accent); color:#1a0f00;}

.banner-card .kicker{position:absolute; top:12px; right:14px; font:700 9px/1 var(--f-mono); letter-spacing:0.1em; padding:4px 8px; border-radius:var(--r-sm); background:rgba(0,0,0,0.55); color:#fff; text-transform:uppercase; border:1px solid rgba(255,255,255,0.18);}

.banner-card.whats{
  background:linear-gradient(135deg, #052e1c 0%, #0c5b3a 100%);
  border-color:rgba(37,211,102,0.45);
}

.banner-card.whats::before{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(90deg, rgba(2,18,12,0.88) 0%, rgba(2,18,12,0.45) 45%, rgba(2,18,12,0.05) 100%);
}

.banner-card.amber{
  background:radial-gradient(circle at 85% 30%, rgba(255,154,66,0.50), transparent 55%), linear-gradient(135deg, #2e1a04 0%, #5a2f08 100%);
  border-color:rgba(255,154,66,0.40);
}

.banner-card.violet{
  background:linear-gradient(135deg, #07101e 0%, #0c1729 100%);
  border-color:var(--line-2);
}

.banner-card.violet::before{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(90deg, rgba(7,16,30,0.85) 0%, rgba(7,16,30,0.42) 45%, rgba(7,16,30,0.05) 100%);
}

.banner-card.teal{
  background:linear-gradient(135deg, #052623 0%, #0a1830 100%);
  border-color:rgba(94,234,212,0.40);
}

.banner-card.teal::before{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(90deg, rgba(2,12,20,0.88) 0%, rgba(2,12,20,0.45) 45%, rgba(2,12,20,0.05) 100%);
}

.banner-card.treino{
  background:linear-gradient(135deg, #061528 0%, #0a2e3a 100%);
  border-color:rgba(94,234,212,0.40);
}

.banner-card.treino::before{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(90deg, rgba(2,10,18,0.88) 0%, rgba(2,10,18,0.45) 45%, rgba(2,10,18,0.05) 100%);
}

.banner-card.crimson{
  background:radial-gradient(circle at 85% 30%, rgba(251,113,133,0.45), transparent 55%), linear-gradient(135deg, #2a0710 0%, #5f1124 100%);
  border-color:rgba(251,113,133,0.40);
}

.banner-card.treino .cta{background:#5eead4; color:#04261f;}

.banner-card.stake-promo{
  background:linear-gradient(135deg, #050a18 0%, #0a1f4a 100%);
  border-color:rgba(77,134,255,0.40);
}

.banner-card.stake-promo .bg-img{object-position:right center;}

.banner-card.stake-promo::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(2,6,16,0.88) 0%, rgba(2,6,16,0.5) 40%, rgba(2,6,16,0.05) 100%);
  z-index:1; pointer-events:none;
}

.banner-card.stake-promo .cta{
  background:linear-gradient(180deg, var(--brand-gold-2) 0%, var(--brand-gold) 100%);
  color:#1a0f00;
  box-shadow:0 4px 14px rgba(245,185,66,0.42);
}

.banner-card.stake-promo .cta:hover{filter:brightness(1.08);}

.banner-card .bg-img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  z-index:0;
  pointer-events:none;
}

.banner-card .kicker{z-index:3;}

.banner-card > div{position:relative; z-index:2;}

.banner-card > .cta, .banner-card > button.cta, .banner-card > span.cta{position:relative; z-index:2;}

.promo-track{display:flex; gap:14px; overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none; padding:6px 2px;}

.promo-track::-webkit-scrollbar{display:none;}

.promo-item{flex:0 0 auto; width:78px; scroll-snap-align:start; display:flex; flex-direction:column; align-items:center; gap:8px; text-decoration:none; color:inherit;}

.promo-bubble{position:relative; width:62px; height:62px; border-radius:50%;
  background:radial-gradient(circle at 30% 22%, #1a3d33 0%, #0e2820 45%, #051813 90%);
  border:1.5px solid rgba(48,224,170,0.22);
  display:flex; align-items:center; justify-content:center;}

.promo-bubble.img{padding:0; background:var(--bg-2); border-color:var(--line-2);}

.promo-bubble.img > img{width:100%; height:100%; object-fit:cover; border-radius:50%;}

.promo-bubble.betmgm-bubble {
  background:#050505;
  border-color:rgba(211,184,118,0.55);
  box-shadow:0 0 0 1px rgba(211,184,118,0.18), 0 10px 24px rgba(0,0,0,0.32);
}
.promo-bubble.betmgm-bubble > img {
  object-fit:contain;
  padding:6px;
  background:#050505;
}

.promo-bubble.live-pulse{
  background:radial-gradient(circle at 30% 22%, #ff8a8a 0%, var(--loss) 50%, #8a1818 100%);
  border-color:rgba(241,90,90,0.6);
  box-shadow:0 0 0 0 rgba(241,90,90,0.6), inset 0 -3px 8px rgba(0,0,0,0.4);
  animation:live-bubble-pulse 1.6s ease infinite;
}

@keyframes live-bubble-pulse{
0%,100%{box-shadow:0 0 0 0 rgba(241,90,90,0.55), inset 0 -3px 8px rgba(0,0,0,0.4);}
50%{box-shadow:0 0 0 8px rgba(241,90,90,0), inset 0 -3px 8px rgba(0,0,0,0.4);}
}

.promo-badge.live-count{
  background:var(--loss); color:#fff;
  min-width:22px; padding:0 7px;
  font:800 10px/18px var(--f-ui);
  letter-spacing:0;
  animation:badge-pulse 1.5s ease infinite;
}

.promo-badge{position:absolute; top:-4px; right:-6px; min-width:18px; height:18px; padding:0 6px; border-radius:999px;
  background:var(--loss); color:#fff; font:700 9px/18px var(--f-ui);
  text-transform:uppercase; box-shadow:0 0 0 2px var(--bg-0), 0 2px 6px rgba(0,0,0,0.5);
  animation:pulse 1.5s ease infinite;}

.promo-label{font:600 11px/1.25 var(--f-ui); color:var(--text-1); text-align:center; max-width:78px;}

/* ===== Balão "Força do dia" — melhor jogador em campo ===== */
.promo-bubble.force-bubble{
  background:var(--bg-2);
  border:2px solid var(--brand-gold, #f5b942);
  box-shadow:0 0 0 0 rgba(245,185,66,0.55), inset 0 -3px 8px rgba(0,0,0,0.35);
  animation:force-bubble-pulse 2s ease infinite;
}
.promo-bubble.force-bubble > img{width:100%; height:100%; object-fit:cover; border-radius:50%;}
.force-initial{font:800 22px/1 var(--f-ui); color:var(--brand-gold, #f5b942); text-transform:uppercase;}
@keyframes force-bubble-pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(245,185,66,0.55), inset 0 -3px 8px rgba(0,0,0,0.35);}
  50%{box-shadow:0 0 0 7px rgba(245,185,66,0), inset 0 -3px 8px rgba(0,0,0,0.35);}
}
.force-item .promo-badge{ right:-6px; top:-4px; }
.promo-badge.force-badge-live{
  background:var(--win, #36d399); color:#04210f;
  min-width:auto; width:16px; height:16px; padding:0; border-radius:50%;
  font:700 9px/16px var(--f-ui); letter-spacing:0; text-align:center;
  box-shadow:0 0 0 2px var(--bg-0), 0 1px 4px rgba(0,0,0,0.5);
}
.promo-badge.force-badge-soon{
  background:var(--brand-gold, #f5b942); color:#241803;
  min-width:auto; padding:0 6px; font:800 9px/18px var(--f-ui); letter-spacing:0; animation:none;
}
.force-label{color:var(--brand-gold, #f5b942); font-weight:700;}


.tabs{display:inline-flex; gap:2px; background:var(--bg-2); border:1px solid var(--line-2); border-radius:8px; padding:2px;}

.tabs button{padding:6px 12px; border:none; cursor:pointer; background:transparent; color:var(--text-2); font:600 11px/1 var(--f-mono); letter-spacing:0.06em; text-transform:uppercase; border-radius:6px;}

.tabs button.active{background:var(--accent-bg); color:var(--accent); border:1px solid var(--accent-bd);}

.sq-row{
  display:grid;
  grid-template-columns:72px 1fr auto;
  gap:14px;
  align-items:center;
  padding:14px 18px;
  border-bottom:1px solid var(--line-1);
  transition:background .12s;
  position:relative;
}

.sq-row:hover{background:rgba(44,107,255,0.05);}

.sq-row:last-child{border-bottom:none;}

.sq-time{
  display:flex; flex-direction:column; align-items:flex-start; gap:3px;
  font:800 14px/1 var(--f-mono);
  color:var(--text-0);
  letter-spacing:-0.01em;
}

.sq-time small{
  font:700 9px/1 var(--f-mono);
  color:var(--text-3);
  letter-spacing:0.10em;
  text-transform:uppercase;
}

.sq-time.live small{color:var(--accent);}

.sq-countdown{display:inline-flex; align-items:center; gap:4px; font:700 11px/1 var(--f-mono); color:var(--accent);}

.sq-countdown .pulse{width:6px; height:6px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 0 var(--accent); animation:pulse 1.4s infinite;}

.sq-info{min-width:0;}

.sq-match{display:flex; align-items:center; gap:8px; flex-wrap:wrap; color:var(--text-0); font:700 13.5px/1.2 var(--f-ui); margin-bottom:5px; letter-spacing:-0.005em;}

.sq-match .vs{color:var(--text-3); font:600 11px/1 var(--f-mono);}

.sq-match .tm{color:var(--text-3); font-weight:400; font-size:11.5px; margin-left:-3px;}

.sq-match .league{display:inline-block; font:600 9px/1 var(--f-mono); letter-spacing:0.06em; color:var(--text-3); text-transform:uppercase; padding:3px 7px; border-radius:var(--r-sm); border:1px solid var(--line-2); background:var(--bg-2); margin-left:4px;}

.sq-match .league.b12{color:var(--brand-blue-2); border-color:var(--brand-blue-bd); background:var(--brand-blue-bg);}

.sq-match .league.b8{color:var(--accent); border-color:var(--accent-bd); background:var(--accent-bg);}

.sq-match .league.cla{color:var(--loss); border-color:rgba(241,90,90,0.32); background:rgba(241,90,90,0.10);}

.sq-pick{font:600 10.5px/1.4 var(--f-mono); color:var(--text-3); letter-spacing:0.04em;}

.sq-pick b{color:var(--accent); font-weight:700;}

.sq-pick .dot{color:var(--text-3); margin:0 5px;}

.sq-cta{
  padding:8px 12px;
  background:var(--brand-blue-bg);
  border:1px solid var(--brand-blue-bd);
  color:var(--brand-blue-2);
  font:800 11px/1 var(--f-mono);
  letter-spacing:0.05em; text-transform:uppercase;
  border-radius:8px;
  display:inline-flex; align-items:center; justify-content:center; gap:5px;
  cursor:pointer; text-decoration:none;
  transition:transform .14s, box-shadow .14s;
}

.sq-cta.gold{
  background:linear-gradient(180deg, #1475E1, #0D5CC4);
  color:#fff; border-color:transparent;
  box-shadow:0 4px 12px rgba(20,117,225,0.28);
}

.sq-cta.gold:hover{transform:translateY(-1px) scale(1.03); box-shadow:0 6px 22px rgba(20,117,225,0.55);}

.sq-cta.esportiva{
  background:linear-gradient(180deg, #FF6220, #CC4010);
  color:#1a0800; border-color:transparent;
  box-shadow:0 4px 12px rgba(255,98,32,0.22);
}

.sq-cta.esportiva:hover{transform:translateY(-1px) scale(1.03); box-shadow:0 6px 22px rgba(255,98,32,0.55);}

.sq-cta.analyze{background:var(--accent-bg); color:var(--accent); border-color:var(--accent-bd);}

.sq-cta.analyze:hover{background:rgba(245,185,66,0.20);}

.live-carousel{display:flex; gap:12px; overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none; padding:14px; scroll-behavior:smooth;}

.live-carousel::-webkit-scrollbar{display:none;}

.carousel-dots{
  display:flex; justify-content:center; gap:5px;
  padding:0 14px 12px;
}

.carousel-dots span{
  width:6px; height:6px; border-radius:50%;
  background:var(--line-2); cursor:pointer; transition:.18s ease;
}

.carousel-dots span.active{
  background:var(--accent); width:18px; border-radius:3px;
}

.swipe-hint{
  display:none;
  text-align:center; padding:4px 0 10px;
  font:600 9.5px/1 var(--f-mono); letter-spacing:0.1em; text-transform:uppercase;
  color:var(--text-3);
}

.swipe-hint::before{content:"← "; opacity:0.6;}

.swipe-hint::after{content:" →"; opacity:0.6;}

.live-card{
  flex:0 0 min(360px, calc(100vw - 32px)); scroll-snap-align:start;
  background:rgba(8,18,33,0.55); border:1px solid var(--line-2); border-radius:var(--r-md);
  display:flex; flex-direction:column; overflow:hidden;
  transition:border-color .12s, transform .12s;
}

.live-card:hover{border-color:var(--accent-bd); transform:translateY(-2px);}

.live-card-head{
  padding:9px 12px; display:flex; align-items:center; gap:8px;
  border-bottom:1px solid var(--line-1);
  background:rgba(7,16,30,0.5);
}

.lg-badge{display:inline-flex; align-items:center; font:600 9.5px/1 var(--f-mono); letter-spacing:0.08em; padding:4px 8px; border-radius:var(--r-sm); text-transform:uppercase;
  background:var(--bg-2); color:var(--text-3); border:1px solid var(--line-2);}

.lg-badge.b8{color:var(--brand-blue-2); border-color:var(--brand-blue-bd); background:var(--brand-blue-bg);}

.lg-badge.b12{color:var(--accent); border-color:var(--accent-bd); background:var(--accent-bg);}

.lg-badge.cla{color:var(--loss); border-color:rgba(241,90,90,0.32); background:rgba(241,90,90,0.10);}

.lg-time{font:700 11px/1 var(--f-mono); color:var(--loss); margin-left:auto; display:inline-flex; align-items:center; gap:6px;}

.lg-time::before{content:""; width:6px; height:6px; border-radius:50%; background:var(--loss); animation:pulse 1.4s infinite;}

.lg-time.upcoming{color:var(--text-2);}

.lg-time.upcoming::before{display:none;}

.live-teams{padding:12px; display:grid; grid-template-columns:1fr auto; gap:8px 12px; align-items:center;}

.player-row{display:flex; align-items:center; gap:9px; min-width:0;}

.player-photo{
  width:28px; height:28px; border-radius:50%;
  background:var(--bg-3); border:1px solid var(--line-2);
  display:inline-flex; align-items:center; justify-content:center;
  font:700 11px/1 var(--f-ui); color:var(--accent);
  overflow:hidden; flex:0 0 28px;
}

.player-photo img{width:100%; height:100%; object-fit:cover; display:block;}

.player-meta{min-width:0;}

.player-meta b{font:600 13px/1.1 var(--f-ui); color:var(--text-0);}

.player-meta b .tm{color:var(--text-3); margin-left:5px; font-weight:400; font-size:11px;}

.player-meta small{display:block; font:500 10px/1 var(--f-mono); color:var(--text-3); margin-top:3px; letter-spacing:0.04em;}

.player-score{font:700 18px/1 var(--f-mono); color:var(--text-0); text-align:right; min-width:18px;}

.player-score.upcoming{font-size:11px; color:var(--text-3); letter-spacing:0;}

.insight-strip{
  margin:0 12px 10px;
  padding:8px 10px;
  display:flex; align-items:center; gap:8px;
  border-radius:var(--r-sm);
  background:rgba(245,185,66,0.07);
  border:1px solid rgba(245,185,66,0.20);
  font:500 11px/1.3 var(--f-ui);
  color:var(--text-1);
}

.insight-strip .ico{flex:0 0 16px; width:16px; height:16px; color:var(--accent);}

.insight-strip b{color:var(--text-0); font-weight:600;}

.insight-strip.hot{background:rgba(241,90,90,0.08); border-color:rgba(241,90,90,0.25);}

.insight-strip.hot .ico{color:var(--loss);}

.insight-strip.cold{background:rgba(94,177,255,0.08); border-color:rgba(94,177,255,0.25);}

.insight-strip.cold .ico{color:var(--brand-blue-2);}

.insight-strip.win{background:rgba(54,211,153,0.08); border-color:rgba(54,211,153,0.25);}

.insight-strip.win .ico{color:var(--win);}

.live-cta-row{
  padding:0 12px 12px;
  display:grid; grid-template-columns:1fr 1fr 1fr;
  gap:6px;
}

.live-cta-row.single{grid-template-columns:1fr;}

.live-cta-row.single .sq-cta{padding:10px 12px;}

.prelive-odds{
  margin:0 12px 10px;
  padding:8px;
  display:grid; grid-template-columns:1fr 1fr 1fr;
  gap:4px;
  background:rgba(7,16,30,0.45);
  border:1px solid var(--line-1);
  border-radius:var(--r-sm);
}

.po-row{
  display:flex; flex-direction:column; align-items:center; gap:3px;
  padding:6px 4px;
  border-radius:var(--r-sm);
  background:rgba(18,35,64,0.5);
  border:1px solid transparent;
}

.po-row.featured{background:var(--accent-bg); border-color:var(--accent-bd);}

.po-lbl{font:600 9px/1 var(--f-mono); color:var(--text-3); letter-spacing:0.06em; text-transform:uppercase;}

.po-val{font:800 13px/1 var(--f-mono); color:var(--text-0); letter-spacing:-0.01em;}

.po-row.featured .po-val{color:var(--accent);}

.mural-grid{display:grid; grid-template-columns:1fr 1fr; gap:12px; padding:14px;}

.mural-item{
  display:flex; flex-direction:column; gap:0;
  padding:0;
  background:rgba(8,18,33,0.45); border:1px solid var(--line-1);
  border-radius:var(--r-md); overflow:hidden;
}

.mural-head{
  display:flex; align-items:center; gap:10px;
  padding:10px 14px;
  border-bottom:1px solid var(--line-1);
  font:700 10px/1 var(--f-mono); letter-spacing:0.12em; text-transform:uppercase;
}

.mural-head .pill{
  padding:3px 8px; border-radius:var(--r-sm);
  font:700 9.5px/1 var(--f-mono); letter-spacing:0.08em;
}

.mural-head .pill.new{background:rgba(54,211,153,0.14); color:var(--win); border:1px solid rgba(54,211,153,0.35);}

.mural-head .pill.fix{background:var(--accent-bg); color:var(--accent); border:1px solid var(--accent-bd);}

.mural-head .pill.info{background:var(--brand-blue-bg); color:var(--brand-blue-2); border:1px solid var(--brand-blue-bd);}

.mural-head .pill.hot{background:rgba(241,90,90,0.14); color:var(--loss); border:1px solid rgba(241,90,90,0.35);}

.mural-head .pill.warn{background:rgba(245,185,66,0.16); color:var(--accent); border:1px solid var(--accent-bd);}

.mural-head .pill.win{background:rgba(54,211,153,0.14); color:var(--win); border:1px solid rgba(54,211,153,0.35);}

.mural-head .kicker{display:inline-flex; align-items:center; gap:6px; color:var(--text-3);}

.mural-head .kicker::before{content:""; width:5px; height:5px; border-radius:50%; background:currentColor;}

.mural-head .when{margin-left:auto; color:var(--text-3); font:500 10px/1 var(--f-mono); letter-spacing:0.06em; text-transform:none;}

.mural-body{padding:12px 14px 12px; flex:1; min-width:0; display:flex; flex-direction:column;}

.mural-h-row{display:flex; align-items:center; gap:10px; margin-bottom:6px;}

.mural-avatar{width:36px; height:36px; border-radius:50%; background:var(--bg-3); border:1px solid var(--line-2); overflow:hidden; display:inline-flex; align-items:center; justify-content:center; font:700 13px/1 var(--f-ui); color:var(--accent); flex:0 0 36px;}

.mural-avatar img{width:100%; height:100%; object-fit:cover; display:block;}

.mural-h-row .h{margin-bottom:0;}

.mural-body .h{font:700 13px/1.25 var(--f-ui); color:var(--text-0); margin-bottom:6px; letter-spacing:-0.005em;}

.mural-body .h em{color:var(--accent); font-style:normal;}

.mural-body .h em.win{color:var(--win);}

.mural-body .h em.loss{color:var(--loss);}

.mural-body .p{font:500 12px/1.4 var(--f-ui); color:var(--text-2); margin:0 0 10px;}

.mural-body .p b{color:var(--text-1); font-weight:600;}

.mural-body .row-foot{display:flex; align-items:center; justify-content:space-between; gap:8px;}

.mural-body .d{font:600 10px/1 var(--f-mono); color:var(--text-3); letter-spacing:0.06em;}

.mural-cta{font:700 10.5px/1 var(--f-mono); letter-spacing:0.06em; text-transform:uppercase; padding:6px 10px; border-radius:var(--r-sm); background:var(--bg-2); color:var(--text-2); border:1px solid var(--line-2); cursor:pointer; text-decoration:none; transition:.12s ease;}

.mural-cta:hover{border-color:var(--accent-bd); color:var(--accent); background:var(--accent-bg);}

.metrics-strip{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:6px;
  margin:8px 0 10px;
}

.metric-cell{
  display:flex; flex-direction:column; gap:3px;
  padding:7px 8px;
  background:rgba(7,16,30,0.45);
  border:1px solid var(--line-1);
  border-radius:var(--r-sm);
}

.metric-cell .mc-v{font:800 14px/1 var(--f-mono); color:var(--text-0); letter-spacing:-0.01em;}

.metric-cell .mc-v.win{color:var(--win);}

.metric-cell .mc-v.loss{color:var(--loss);}

.metric-cell .mc-v.gold{color:var(--accent);}

.metric-cell .mc-l{font:600 9px/1 var(--f-mono); color:var(--text-3); letter-spacing:0.06em; text-transform:uppercase;}

.interact-grid{display:grid; grid-template-columns:1fr 1fr 1fr; gap:12px; padding:14px;}

.interact-card{padding:14px; background:rgba(8,18,33,0.45); border:1px solid var(--line-1); border-radius:var(--r-md);}

.interact-card .ic-head{display:flex; align-items:center; gap:8px; font:600 12px/1 var(--f-ui); color:var(--text-0); margin-bottom:12px;}

.interact-card .ic-head .ic-ic{width:20px; height:20px; border-radius:var(--r-sm); display:inline-flex; align-items:center; justify-content:center; background:var(--accent-bg); color:var(--accent);}

.rank-row{display:grid; grid-template-columns:22px 26px 1fr auto; gap:9px; align-items:center; padding:6px 8px; border-radius:var(--r-sm); margin-bottom:4px;}

.rank-row:hover{background:var(--bg-2);}

.rank-row .pos{font:800 13px/1 var(--f-mono); color:var(--accent); text-align:center;}

.rank-row .ph{width:26px; height:26px; border-radius:50%; background:var(--bg-3); border:1px solid var(--line-2); overflow:hidden; display:inline-flex; align-items:center; justify-content:center; font:700 10px/1 var(--f-ui); color:var(--accent); flex:0 0 26px;}

.rank-row .ph img{width:100%; height:100%; object-fit:cover; display:block;}

.rank-row .who{font:600 12px/1.2 var(--f-ui); color:var(--text-0); min-width:0;}

.rank-row .who small{display:block; font:500 10px/1 var(--f-mono); color:var(--text-3); margin-top:3px; letter-spacing:0.04em;}

.rank-row .v{font:800 12px/1 var(--f-mono); color:var(--accent); text-align:right;}

.rank-row .v.muted{color:var(--text-2);}

.pot-row{display:grid; grid-template-columns:90px 1fr 44px; gap:10px; align-items:center; margin-bottom:10px;}

.pot-row .lbl{font:600 11px/1 var(--f-mono); color:var(--text-2); letter-spacing:0.04em;}

.pot-row .bar{height:6px; border-radius:3px; background:rgba(255,255,255,0.05); overflow:hidden;}

.pot-row .bar .fill{height:100%; background:linear-gradient(90deg, var(--accent), var(--brand-gold-2)); border-radius:3px;}

.pot-row .pct{font:800 11px/1 var(--f-mono); color:var(--accent); text-align:right;}

.pot-row .pct.warn{color:#ffb84d;}

.streak-row{display:flex; align-items:center; gap:10px; padding:6px 8px; border-radius:var(--r-sm); margin-bottom:4px;}

.streak-row:hover{background:var(--bg-2);}

.streak-row .ph{width:26px; height:26px; border-radius:50%; background:var(--bg-3); border:1px solid var(--line-2); overflow:hidden; display:inline-flex; align-items:center; justify-content:center; font:700 10px/1 var(--f-ui); color:var(--accent); flex:0 0 26px;}

.streak-row .ph img{width:100%; height:100%; object-fit:cover; display:block;}

.streak-row .player{flex:1; font:600 12px/1.2 var(--f-ui); color:var(--text-0); min-width:0;}

.streak-row .player small{display:block; font:500 10px/1 var(--f-mono); color:var(--text-3); margin-top:3px;}

.streak-row .sbd{font:800 11px/1 var(--f-mono); color:var(--accent); display:inline-flex; align-items:center; gap:5px; padding:5px 9px; border-radius:var(--r-sm); background:var(--accent-bg); border:1px solid var(--accent-bd);}

@media (max-width: 900px){
.app{grid-template-columns:1fr;}
/* removido em phase15: deixa sidebar virar bottom-nav no mobile */
.topbar{grid-template-columns:1fr auto; gap:10px; padding:10px 14px;}
.search{display:none;}
.ticker{display:none;}
.content{padding:14px 12px 60px;}
}

@media (max-width: 768px){
.topbar{padding:8px 12px;}
.crumbs{font-size:11px;}
.user-chip .rl{display:none;}
.user-chip .nm{font-size:11px;}
.page-head{flex-direction:column; align-items:flex-start; gap:8px;}
.page-title{font-size:19px;}
.page-sub{font-size:10px;}
.banners-row{padding:2px 0 6px;}
.banner-card{flex:0 0 calc(100% - 28px); height:118px; padding:14px 16px;}
.banner-card .h{font-size:16px;}
.banner-card .sub{font-size:11.5px; max-width:90%;}
.banner-card .cta{font-size:10px; padding:7px 11px;}
.banner-card .kicker{font-size:8.5px; top:10px; right:10px;}
.banners-arrow{display:none;}
.banners-dots{margin-top:8px;}
.kpis{grid-template-columns:1fr 1fr; gap:10px;}
.kpi-tile{padding:12px;}
.kpi-tile .val{font-size:22px;}
.kpi-tile .delta{font-size:10px; padding:2px 7px;}
.card-head{padding:10px 12px;}
.card-title{font-size:12px;}
.promo-bubble{width:56px; height:56px;}
.promo-bubble .icon{width:26px; height:26px;}
.promo-label{font-size:10.5px;}
.promo-item{width:72px;}
.sq-row{grid-template-columns:60px 1fr auto; padding:11px 12px; gap:10px;}
.sq-time{font-size:13px;}
.sq-time small{font-size:8.5px;}
.sq-match{font-size:12px; gap:5px;}
.sq-match .tm{font-size:10px;}
.sq-match .vs{font-size:10px;}
.sq-match .league{font-size:8px; padding:2px 5px;}
.sq-pick{font-size:9.5px;}
.sq-pick .dot{margin:0 3px;}
.sq-cta{padding:7px 10px; font-size:10px;}
.tabs button{padding:5px 9px; font-size:10px;}
.live-carousel{padding:10px;}
.live-card{flex:0 0 calc(100% - 24px);}
.live-card-head{padding:8px 12px;}
.live-teams{padding:10px 12px; gap:6px 10px;}
.player-meta b{font-size:12.5px;}
.player-meta b .tm{font-size:10px;}
.player-meta small{font-size:9.5px;}
.player-score{font-size:18px;}
.insight-strip{margin:0 10px 8px; padding:7px 9px; font-size:10.5px;}
.live-cta-row{grid-template-columns:1fr 1fr; padding:0 10px 10px; gap:5px;}
.live-cta-row .sq-cta.analyze{grid-column:1 / -1;}
.prelive-odds{margin:0 10px 8px; padding:6px; gap:3px;}
.po-lbl{font-size:8px;}
.po-val{font-size:11.5px;}
.mural-grid{grid-template-columns:1fr; gap:8px; padding:12px;}
.mural-item{padding:10px;}
.mural-head{padding:9px 11px; font-size:9px;}
.mural-body{padding:10px 11px;}
.mural-body .h{font-size:12px;}
.mural-body .p{font-size:11px;}
.mural-cta{font-size:9.5px; padding:5px 8px;}
.interact-grid{grid-template-columns:1fr; gap:10px; padding:12px;}
.interact-card{padding:12px;}
.interact-card .ic-head{font-size:11px;}
.rank-row{padding:6px 8px;}
.rank-row .who{font-size:11.5px;}
.pot-row{grid-template-columns:78px 1fr 40px; gap:8px;}
.pot-row .lbl{font-size:10px;}
.streak-row .player{font-size:11.5px;}
.live-carousel{padding:10px 12px; gap:10px;}
.live-card{flex:0 0 78%;}
.player-photo{width:24px; height:24px; flex:0 0 24px;}
.live-card-head{padding:7px 10px;}
.live-teams{padding:8px 10px; gap:5px 10px;}
.insight-strip{margin:0 10px 7px; padding:6px 8px; font-size:10px;}
.live-cta-row .sq-cta{padding:7px 8px; font-size:9.5px;}
.sq-row{grid-template-columns:56px 1fr auto; padding:10px 12px; gap:9px;}
.sq-time{font-size:13px;}
.sq-time small{font-size:8px;}
.sq-match{font-size:11.5px; flex-wrap:wrap; gap:4px; margin-bottom:3px;}
.sq-match .tm, .sq-match .vs{font-size:9.5px;}
.sq-match .league{font-size:7.5px; padding:2px 5px;}
.sq-pick{font-size:9px;}
.sq-cta{padding:6px 10px; font-size:9.5px;}
.mural-grid{display:flex; flex-direction:column; gap:6px; padding:10px;}
.mural-item{flex-direction:row;}
.mural-head{
    padding:8px 10px; font-size:8.5px;
    border-bottom:0; border-right:1px solid var(--line-1);
    flex-direction:column; align-items:flex-start; gap:4px;
    min-width:90px; flex:0 0 90px;
  }
.mural-head .when{display:none;}
.mural-body{padding:9px 11px; flex:1; min-width:0;}
.mural-body .h{font-size:11.5px; margin-bottom:3px;}
.mural-body .p{
    font-size:10.5px; margin-bottom:6px;
    -webkit-line-clamp:2; display:-webkit-box; -webkit-box-orient:vertical; overflow:hidden;
  }
.mural-cta{font-size:9px; padding:4px 7px;}
.interact-grid{
    display:flex !important;
    grid-template-columns:none !important;
    overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
    gap:10px; padding:10px 12px;
  }
.interact-grid::-webkit-scrollbar{display:none;}
.interact-card{flex:0 0 78%; scroll-snap-align:start; min-width:0;}
.swipe-hint{display:block;}
}

@media (max-width: 480px){
.content{padding:10px 10px 50px;}
.topbar{padding:6px 10px; gap:6px;}
.crumbs{font-size:10px;}
.user-chip{padding:4px 9px 4px 4px;}
.user-chip .av{width:22px; height:22px;}
.page-title{font-size:17px;}
.banner-card{flex:0 0 calc(100% - 20px); height:104px; padding:12px 14px;}
.banner-card .h{font-size:14.5px;}
.banner-card .sub{font-size:11px;}
.kpis{grid-template-columns:1fr 1fr; gap:8px;}
.sq-row{grid-template-columns:1fr; gap:8px; padding:10px 12px;}
.sq-row > .sq-time{display:inline-flex; flex-direction:row; align-items:center; gap:8px;}
.sq-row > .sq-time small{margin-left:2px;}
.sq-row > .sq-cta{justify-self:stretch; text-align:center; width:100%;}
.live-teams{grid-template-columns:1fr auto; gap:5px 10px;}
.player-score{font-size:16px;}
.mural-head .when{display:none;}
}

/* ===== jogos-v2-preview.html ===== */
body::before{
  content:''; position:fixed; inset:0; pointer-events:none; z-index:0;
  background-image:
    linear-gradient(rgba(120,180,255,0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(120,180,255,0.07) 1px, transparent 1px);
  background-size:44px 44px;
}

@keyframes pulse{
0%{box-shadow:0 0 0 0 rgba(241,90,90,0.5);}
70%{box-shadow:0 0 0 6px rgba(241,90,90,0);}
100%{box-shadow:0 0 0 0 rgba(241,90,90,0);}
}

.app{display:grid; grid-template-columns:240px 1fr; min-height:100vh; position:relative; z-index:1;}



.brand{padding:18px 20px 16px; border-bottom:1px solid var(--line-1); display:flex; align-items:center; gap:10px;}


















.topbar{display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:20px; padding:12px 24px; background:rgba(7,16,30,0.85); border-bottom:1px solid var(--line-1); position:sticky; top:0; z-index:10; backdrop-filter:blur(10px);}

.crumbs{display:flex; align-items:center; gap:8px; font:500 12px/1 var(--f-mono); color:var(--text-3);}

.crumbs .sep{opacity:0.5;}

.crumbs .cur{color:var(--text-0);}

.search{position:relative; max-width:420px; width:100%; justify-self:center;}

.search input{width:100%; background:var(--bg-2); border:1px solid var(--line-1); border-radius:var(--r-md); color:var(--text-1); padding:8px 12px 8px 34px; font:500 12.5px/1 var(--f-ui); outline:none;}

.search input:focus{border-color:var(--accent-bd);}

.search input::placeholder{color:var(--text-3);}

.search .si{position:absolute; left:11px; top:50%; transform:translateY(-50%); color:var(--text-3); width:14px; height:14px;}

.search .kbd{position:absolute; right:10px; top:50%; transform:translateY(-50%); font:500 10px/1 var(--f-mono); color:var(--text-3); background:var(--bg-3); padding:3px 6px; border-radius:3px; border:1px solid var(--line-1);}

.user-chip{display:flex; align-items:center; gap:8px; padding:5px 12px 5px 5px; border:1px solid var(--line-2); border-radius:999px; background:var(--bg-2); cursor:pointer;}

.user-chip .av{width:24px; height:24px; border-radius:50%; background:linear-gradient(135deg, var(--accent), var(--brand-gold-dim)); display:grid; place-items:center; color:#06101e; font:600 10px/1 var(--f-mono);}

.user-chip .nm{font:600 12px/1 var(--f-ui); color:var(--text-0);}

.user-chip .rl{font:500 10px/1 var(--f-mono); color:var(--text-3); text-transform:uppercase; margin-top:2px;}

.content{padding:20px 24px 60px; min-width:0; max-width:1600px;}

.page-hero{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:24px; gap:20px;
}

.page-hero h1{
  font:800 28px/1 var(--f-ui); letter-spacing:-0.02em; color:var(--text-0);
  text-transform:uppercase;
  margin:0;
}

.filter-tabs{display:flex; gap:8px;}

.filter-tab{
  padding:8px 16px; border-radius:var(--r-sm);
  font:700 11px/1 var(--f-mono); letter-spacing:0.08em; text-transform:uppercase;
  background:var(--bg-2); color:var(--text-2); border:1px solid var(--line-2);
  cursor:pointer; transition:.12s ease;
  display:inline-flex; align-items:center; gap:6px;
}

.filter-tab:hover{border-color:var(--accent-bd); color:var(--text-1);}

.filter-tab.active{background:var(--loss); color:#fff; border-color:transparent; box-shadow:0 4px 12px rgba(241,90,90,0.32);}

.filter-tab .arr{font-size:9px; opacity:0.7;}

.filter-tab .dot-live{
  width:7px; height:7px; border-radius:50%; background:#fff;
  box-shadow:0 0 0 0 rgba(255,255,255,0.6);
  animation:pulse-white 1.4s infinite;
}

@keyframes pulse-white{
0%{box-shadow:0 0 0 0 rgba(255,255,255,0.65);}
70%{box-shadow:0 0 0 6px rgba(255,255,255,0);}
100%{box-shadow:0 0 0 0 rgba(255,255,255,0);}
}

.filter-tab .cnt{
  font:700 10px/1 var(--f-mono);
  padding:3px 6px; border-radius:var(--r-sm);
  background:rgba(255,255,255,0.18); color:#fff;
}

.filter-tab:not(.active) .cnt{background:var(--bg-3); color:var(--text-2);}

.filter-tab .cnt-muted{background:var(--bg-3); color:var(--text-3);}

.league-section{margin-bottom:30px;}

.league-head{
  display:flex; align-items:center; gap:10px;
  margin-bottom:6px;
}

.league-head .icon{
  width:22px; height:22px; border-radius:50%;
  background:linear-gradient(135deg, var(--brand-blue-2), var(--brand-blue));
  display:grid; place-items:center;
  flex:0 0 22px;
}

.league-head .icon svg{width:14px; height:14px; color:#fff;}

.league-head .name{
  font:700 16px/1 var(--f-ui); color:var(--text-0);
  display:flex; align-items:center; gap:5px;
  letter-spacing:-0.01em;
}

.league-head .name .arr{color:var(--text-3); font-size:12px;}

.league-head .star{margin-left:auto; color:var(--text-3); cursor:pointer; font-size:18px; transition:.12s ease;}

.league-head .star:hover, .league-head .star.active{color:var(--accent);}

.league-sub{font:500 12px/1.3 var(--f-ui); color:var(--text-3); margin:0 0 12px 32px;}

.match-row{
  display:grid;
  grid-template-columns:minmax(280px, 1fr) auto;
  gap:0;
  background:var(--bg-card);
  border:1px solid var(--line-2);
  border-radius:var(--r-md);
  overflow:hidden;
  margin-bottom:8px;
  transition:border-color .12s, background .12s;
  cursor:pointer;
}

.match-row:hover{border-color:var(--accent-bd); background:rgba(18,35,64,0.75);}

.match-info{
  padding:8px 12px;
  border-right:1px solid var(--line-1);
  display:flex; flex-direction:column; gap:5px;
}

.match-info .top{
  display:flex; align-items:center; gap:6px;
  font:600 9.5px/1 var(--f-mono); letter-spacing:0.06em;
  margin-bottom:1px;
}

.match-info .top .tempo{color:var(--win); text-transform:uppercase;}

.match-info .top .min{color:var(--win); display:inline-flex; align-items:center; gap:4px;}

.match-info .top .cam{
  display:inline-flex; align-items:center; justify-content:center;
  width:14px; height:12px; border-radius:3px;
  background:var(--loss); color:#fff;
}

.match-info .top .cam svg{width:8px; height:8px;}

.match-info .top .period{margin-left:auto; color:var(--text-3); text-transform:uppercase; font-size:9px;}

.match-info .team{
  display:flex; align-items:center; gap:8px;
  font:600 12px/1.15 var(--f-ui); color:var(--text-0);
}

.match-info .team .pl{color:var(--text-3); font-weight:400; font-size:10.5px;}

.match-info .team .pl::before{content:"("; color:var(--text-3);}

.match-info .team .pl::after{content:")"; color:var(--text-3);}

.match-info .team .score{margin-left:auto; font:700 13px/1 var(--f-mono); color:var(--text-0); min-width:14px; text-align:right;}

.match-info .team.winning .score{color:var(--win);}

.match-odds-wrap{
  padding:8px 12px;
  display:flex; align-items:stretch; gap:10px;
  min-width:580px;
}

.market-group{
  display:flex; flex-direction:column; gap:4px;
}

.market-group .market-name{
  font:600 8.5px/1 var(--f-mono); color:var(--text-3);
  letter-spacing:0.08em; text-transform:uppercase;
  white-space:nowrap;
}

.market-cells{display:flex; gap:4px;}

.odd-cell{
  flex:0 0 56px;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2px;
  padding:6px 4px;
  background:var(--bg-2);
  border:1px solid var(--line-2);
  border-radius:var(--r-sm);
  transition:.12s ease;
  cursor:pointer;
}

.odd-cell:hover{border-color:var(--accent-bd); background:var(--accent-bg);}

.odd-cell .lbl{font:700 8.5px/1 var(--f-mono); color:var(--text-3); letter-spacing:0.04em; text-transform:uppercase;}

.odd-cell .val{font:800 12px/1 var(--f-mono); color:var(--text-0); letter-spacing:-0.01em;}

.odd-cell:hover .val{color:var(--accent);}

.market-divider{width:1px; background:var(--line-1); align-self:stretch; margin:14px 0 0;}

.analisar-btn{
  flex:0 0 auto;
  margin-left:auto;
  align-self:flex-end;
  display:inline-flex; align-items:center; justify-content:center; gap:5px;
  background:var(--accent-bg); border:1px solid var(--accent-bd); border-radius:var(--r-sm);
  color:var(--accent);
  font:700 10px/1 var(--f-mono); letter-spacing:0.08em; text-transform:uppercase;
  cursor:pointer; transition:.15s ease;
  padding:9px 14px;
}

.analisar-btn:hover{background:rgba(245,185,66,0.20); color:var(--brand-gold-2); border-color:var(--brand-gold-2);}

.analisar-btn svg{width:11px; height:11px; transition:transform .15s ease;}

.analisar-btn:hover svg{transform:translateX(2px);}

.casa-hint{
  display:inline-flex; align-items:center; gap:4px;
  margin-top:4px;
  padding:0;
  background:transparent; border:none;
  color:var(--text-3);
  font:500 9.5px/1 var(--f-mono);
  letter-spacing:0.05em;
  white-space:nowrap;
  align-self:flex-end;
}

.casa-hint svg{width:11px; height:11px; opacity:0.7; flex:0 0 11px;}

.casa-hint b{color:var(--text-2); font-weight:600; text-transform:uppercase;}

.casa-hint.stake b{color:#4d86ff;}

.casa-hint.esportiva b{color:#ff7240;}

.casa-hint.superbet b{color:#ff4d4d;}

.match-row:hover .casa-hint{color:var(--text-2);}

.match-row:hover .casa-hint svg{opacity:1;}

.right-stack{display:flex; flex-direction:column; align-items:flex-end; gap:0; margin-left:auto;}

@media (max-width:1200px){
.match-odds-wrap{min-width:480px;}
.market-group:nth-child(5), .market-divider:nth-child(4){display:none;}
}

@media (max-width: 900px){
.app{grid-template-columns:1fr;}
/* removido em phase15: deixa sidebar virar bottom-nav no mobile */
.topbar{grid-template-columns:1fr auto; gap:10px; padding:10px 14px;}
.search{display:none;}
.content{padding:16px 12px 60px;}
}

@media (max-width: 768px){
.match-row{grid-template-columns:1fr;}
.match-info{border-right:0; border-bottom:1px solid var(--line-1);}
.match-odds{grid-template-columns:repeat(3,1fr) 44px;}
.page-hero{flex-direction:column; align-items:flex-start;}
.page-hero h1{font-size:22px;}
.filter-tabs{flex-wrap:wrap;}
}

/* ============================================================
   Phase 7 — Camera vermelha pulsante + player inline /jogos
   ============================================================ */

/* Camera "AO VIVO" — atrai atenção */

.match-row .cam.cam-pulse:hover {
  transform: scale(1.08);
  box-shadow:
    0 0 0 6px rgba(255, 50, 50, 0.0),
    0 4px 10px rgba(220, 20, 30, 0.55);
}
.match-row .cam.cam-pulse svg {
  width: 18px;
  height: 18px;
  filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.3));
}
.match-row .cam.cam-pulse .cam-dot {
  position: absolute;
  top: -2px;
  right: -2px;
  width: 8px;
  height: 8px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 0 0 2px #d40e1e;
  animation: cam-dot-blink 1s ease-in-out infinite;
}
.match-row .cam.cam-pulse.is-open {
  background: linear-gradient(135deg, #1e2734 0%, #0e141e 100%);
  border-color: rgba(255, 60, 60, 0.85);
  animation: none;
}
.match-row .cam.cam-pulse.is-open svg {
  color: #ff4a55;
}

@keyframes cam-live-pulse {
  0%, 100% {
    box-shadow:
      0 0 0 0 rgba(255, 50, 50, 0.55),
      0 2px 6px rgba(220, 20, 30, 0.35);
  }
  50% {
    box-shadow:
      0 0 0 6px rgba(255, 50, 50, 0.0),
      0 2px 6px rgba(220, 20, 30, 0.35);
  }
}
@keyframes cam-dot-blink {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(0.7); }
}

/* Player inline na própria linha */
.match-row-stream {
  margin: 8px 12px 12px;
  border: 1px solid rgba(255, 60, 60, 0.25);
  border-radius: 12px;
  overflow: hidden;
  background: #07101e;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.4);
  animation: stream-slide 0.25s ease-out;
}
.match-row-stream-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  background: linear-gradient(180deg, rgba(255, 60, 60, 0.12), rgba(255, 60, 60, 0.04));
  border-bottom: 1px solid rgba(255, 60, 60, 0.2);
  font-family: var(--f-ui, 'Inter Tight'), sans-serif;
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--text-2, #9aa6b2);
  text-transform: uppercase;
}
.match-row-stream-head .mrs-close {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: var(--text-2, #9aa6b2);
  cursor: pointer;
  padding: 0;
  transition: background 0.15s ease, color 0.15s ease;
}
.match-row-stream-head .mrs-close:hover {
  background: rgba(255, 60, 60, 0.15);
  color: #ff4a55;
}
.match-row-stream .match-video-wrap {
  position: relative;
  width: 100%;
  max-width: 720px;
  margin: 0 auto;
  aspect-ratio: 4/3;
  min-height: 360px;
  max-height: 520px;
  background: #000;
}
@media (max-width: 720px) {
  .match-row-stream .match-video-wrap {
    aspect-ratio: 1/1;
    min-height: 280px;
  }
}
.match-row-stream .match-video-frame {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}
.match-row-stream .match-video-loading {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  color: var(--text-2, #9aa6b2);
  font-family: var(--f-mono, 'JetBrains Mono'), monospace;
  font-size: 11px;
  z-index: 1;
}
.match-row-stream .mv-spinner {
  width: 28px;
  height: 28px;
  border: 2px solid rgba(255, 60, 60, 0.2);
  border-top-color: #ff4a55;
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes stream-slide {
  from { opacity: 0; transform: translateY(-8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Camera live — 30% maior que original (14→18), vermelha, sem fundo gradient pesado */
.match-row .cam.cam-pulse {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  margin-left: 4px;
  border: 1px solid rgba(255, 70, 80, 0.35);
  border-radius: 6px;
  background: rgba(255, 50, 60, 0.10);
  color: #ff4a55;
  cursor: pointer;
  padding: 0;
  transition: transform 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
  position: relative;
}
.match-row .cam.cam-pulse:hover {
  background: rgba(255, 50, 60, 0.20);
  transform: scale(1.08);
  box-shadow: 0 0 0 3px rgba(255, 50, 60, 0.18);
}
.match-row .cam.cam-pulse svg {
  width: 14px;
  height: 14px;
}
.match-row .cam.cam-pulse .cam-dot {
  position: absolute;
  top: -2px;
  right: -2px;
  width: 6px;
  height: 6px;
  background: #ff3344;
  border-radius: 50%;
  box-shadow: 0 0 0 1.5px var(--bg-0, #07101e);
  animation: cam-dot-blink 1.2s ease-in-out infinite;
}
.match-row .cam.cam-pulse.is-open {
  background: rgba(255, 50, 60, 0.22);
  border-color: rgba(255, 70, 80, 0.65);
  color: #ff6a72;
}
@keyframes cam-dot-blink {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(0.7); }
}


/* Phase 13 — Drag scroll nos carousels */
.live-carousel {
  cursor: grab;
  user-select: none;
  -webkit-user-select: none;
}
.live-carousel:active { cursor: grabbing; }
.live-carousel * { pointer-events: auto; }
.live-carousel img { -webkit-user-drag: none; }


/* Phase 14 — Banner mobile + swipe hint */
/* Banner mobile: cards menores pra evitar corte nas laterais */
@media (max-width: 720px) {
  .banners-wrap.v2-banners {
    padding: 0 8px;
  }
  .banners-row {
    scroll-snap-type: x mandatory;
    padding: 4px 8px 8px;
    gap: 10px;
  }
  .banners-row .banner-card {
    flex: 0 0 100% !important;
    max-width: 100%;
    scroll-snap-align: center;
    margin-right: 0;
  }
}

/* Indicador de "tem mais — arraste" — chip discreto no canto do header */
.card-head .swipe-hint {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-left: auto;
  font: 600 10px/1 var(--f-mono, 'JetBrains Mono'), monospace;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-3, #6a7585);
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px dashed rgba(255, 255, 255, 0.10);
  user-select: none;
  pointer-events: none;
}
.card-head .swipe-hint svg {
  width: 11px;
  height: 11px;
  animation: swipe-arrow-pulse 1.4s ease-in-out infinite;
}
@keyframes swipe-arrow-pulse {
  0% { transform: translateX(-2px); opacity: 0.5; }
  50% { transform: translateX(2px); opacity: 1; }
  100% { transform: translateX(-2px); opacity: 0.5; }
}
@media (min-width: 1100px) {
  /* Em desktops largos onde tudo cabe, escondemos o hint pra não poluir */
  .card-head .swipe-hint.desktop-hide-wide { display: none; }
}

/* Player photo fallback estilizada — quando não tem foto, mostra inicial colorida */
.live-card .player-photo {
  background: linear-gradient(135deg, rgba(245,185,66,0.18), rgba(245,185,66,0.04));
  color: var(--accent, #f5b942);
  font: 700 13px/1 var(--f-ui, 'Inter Tight');
  text-transform: uppercase;
}
.live-card .player-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
}


/* Phase 15 — Garante espaço pro bottom-nav no mobile */
@media (max-width: 900px) {
  .content { padding-bottom: 88px !important; }
  /* Sidebar volta a aparecer como bottom-nav (controlado em styles.css) */
}

/* Phase 15 — /jogos mobile match-row vertical layout */
@media (max-width: 720px) {
  .match-row {
    display: flex !important;
    flex-direction: column;
    gap: 10px;
    padding: 12px !important;
  }
  .match-row .match-info {
    width: 100%;
  }
  .match-row .match-info .top {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
  }
  .match-row .team {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 0;
    gap: 8px;
  }
  .match-row .team span:first-child {
    flex: 1;
    font-size: 13px;
    font-weight: 600;
  }
  .match-row .team .score {
    font: 800 16px/1 var(--f-mono);
    min-width: 24px;
    text-align: right;
  }
  .match-row .match-odds-wrap {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    width: 100%;
    min-width: 0 !important;
  }
  .match-row .market-group {
    width: 100%;
  }
  .match-row .market-divider { display: none; }
  .match-row .market-cells {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 6px;
  }
  .match-row .market-group:not(:first-child) .market-cells {
    grid-template-columns: repeat(2, 1fr);
  }
  .match-row .right-stack {
    display: flex;
    gap: 8px;
    width: 100%;
    margin-top: 4px;
  }
  .match-row .analisar-btn {
    flex: 1;
    justify-content: center;
  }
  .match-row .casa-hint {
    flex: 0 0 auto;
  }
  /* Page hero header e tabs */
  .page-hero h1 { font-size: 22px !important; }
  .filter-tabs { flex-wrap: wrap; gap: 6px; }
  .filter-tab { padding: 8px 12px !important; font-size: 11px !important; }
  /* League head: ícone+nome flex */
  .league-section .league-head .icon { width: 26px; height: 26px; }
  .league-section .league-head .name { font-size: 14px; }
}


/* Phase 16 — Carousel arrows + dots (replace swipe-hint) */
.carousel-wrap {
  position: relative;
}
.carousel-wrap .live-carousel { padding-bottom: 24px; }
.carousel-wrap .carousel-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(7, 16, 30, 0.75);
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: var(--text-1, #c7d0db);
  font: 700 18px/1 var(--f-ui, 'Inter Tight');
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 5;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.35);
  transition: all 0.15s ease;
  padding: 0;
}
.carousel-wrap .carousel-arrow:hover {
  background: rgba(7, 16, 30, 0.95);
  border-color: var(--accent, #f5b942);
  color: var(--accent, #f5b942);
  transform: translateY(-50%) scale(1.08);
}
.carousel-wrap .carousel-arrow.prev { left: 4px; }
.carousel-wrap .carousel-arrow.next { right: 4px; }
.carousel-wrap .carousel-dots {
  position: absolute;
  bottom: 4px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 6px;
  z-index: 4;
}
.carousel-wrap .carousel-dots span {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.15);
  cursor: pointer;
  transition: all 0.15s ease;
}
.carousel-wrap .carousel-dots span:hover {
  background: rgba(255, 255, 255, 0.35);
}
.carousel-wrap .carousel-dots span.active {
  background: var(--accent, #f5b942);
  width: 18px;
  border-radius: 3px;
}
/* Remover o estilo do swipe-hint antigo */
.card-head .swipe-hint { display: none !important; }

@media (max-width: 720px) {
  .carousel-wrap .carousel-arrow { width: 28px; height: 28px; font-size: 16px; }
  .carousel-wrap .carousel-arrow.prev { left: 2px; }
  .carousel-wrap .carousel-arrow.next { right: 2px; }
}


/* Phase 17 — Logo no topbar mobile (desktop sidebar já tem brand) */
.topbar-brand {
  display: none;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  overflow: hidden;
  flex: 0 0 auto;
  cursor: pointer;
  text-decoration: none;
  background: #000;
}
.topbar-brand img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
@media (max-width: 900px) {
  .topbar-brand { display: inline-flex; }
  .topbar {
    grid-template-columns: auto 1fr auto !important;
    gap: 10px;
    align-items: center;
  }
  .topbar .crumbs { grid-column: 2; min-width: 0; }
  .topbar .search { grid-column: 1 / -1; grid-row: 2; }
}

/* Phase 17b — Esconder .brand do sidebar quando virar bottom-nav (mobile) */
@media (max-width: 900px) {
  .sidebar .brand { display: none !important; }
}

/* Phase 20 — Eliminar gap excessivo no final da página no mobile */
@media (max-width: 900px) {
  /* .app grid não estica o .main pra ocupar viewport vazio */
  .app {
    align-content: start;
    align-items: start;
    min-height: 0 !important;
  }
  .main {
    align-self: start;
    min-height: 0 !important;
    height: auto !important;
  }
  .content {
    padding-bottom: calc(76px + env(safe-area-inset-bottom, 0)) !important;
    min-height: 0 !important;
  }
  /* Body min-height ajustado p/ não criar overscroll fantasma */
  body { min-height: 100dvh; }
}



/* Phase 27 — 'Pra você hoje' card transparente + img na bolinha */
.card.promo-carousel-card,
.card.v2-promo {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}
.card.promo-carousel-card .card-head,
.card.v2-promo .card-head {
  border-bottom: none !important;
  padding-bottom: 4px;
}
.card.promo-carousel-card .card-body,
.card.v2-promo .card-body {
  background: transparent !important;
  padding: 8px 0 4px;
}
/* Bolinha Jogos ao vivo agora usa img — promo-bubble.live-pulse mantém fundo vermelho do legado */
.promo-bubble.live-pulse > img {
  width: 78%;
  height: 78%;
  object-fit: contain;
  border-radius: 0;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.4));
}

/* Phase 29 — /jogos mobile: lista limpa sem odds */
@media (max-width: 720px) {
  .match-row .market-group,
  .match-row .market-divider {
    display: none !important;
  }
  .match-row .match-odds-wrap {
    min-width: 0 !important;
    width: 100%;
    padding: 0 !important;
  }
  .match-row .right-stack {
    display: flex !important;
    flex-direction: row;
    gap: 8px;
    width: 100%;
    margin: 0;
    padding: 6px 0 0;
  }
  .match-row .analisar-btn {
    flex: 1;
    justify-content: center;
    padding: 9px 12px;
    font-size: 12px;
    font-weight: 700;
  }
  .match-row .casa-hint {
    flex: 0 1 auto;
    padding: 7px 10px;
    font-size: 11px;
    white-space: nowrap;
  }
}

/* Phase 30 — Ícone PS5 controller no título de Partidas ao vivo */
.card-title .title-ico {
  width: 22px;
  height: 22px;
  object-fit: contain;
  margin: 0 6px 0 2px;
  vertical-align: middle;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,0.4));
}
@media (max-width: 720px) {
  .card-title .title-ico { width: 18px; height: 18px; margin: 0 4px 0 2px; }
}

/* ============ Wave improvements — CSS ============ */

/* #12 Goal animation na LiveCard */
/* ===== Goal animation (replicada do legado) ===== */
.goal-num {
  display: inline-block;
  position: relative;
  transition: color 0.2s ease;
}
.goal-num-pop {
  animation: goal-pop 1.6s cubic-bezier(.34,1.56,.64,1) both;
  color: var(--brand-gold, #f5b942);
  text-shadow: 0 0 12px rgba(245,185,66,0.85);
  z-index: 3;
}
@keyframes goal-pop {
  0%   { transform: scale(1);    color: inherit;          text-shadow: none; }
  18%  { transform: scale(1.65); color: var(--brand-gold, #f5b942); text-shadow: 0 0 18px rgba(245,185,66,1), 0 0 28px rgba(245,185,66,0.7); }
  40%  { transform: scale(1.20); color: var(--brand-gold, #f5b942); text-shadow: 0 0 14px rgba(245,185,66,0.8); }
  70%  { transform: scale(1.05); color: var(--brand-gold, #f5b942); text-shadow: 0 0 8px rgba(245,185,66,0.5); }
  100% { transform: scale(1);    color: inherit;          text-shadow: none; }
}

/* Flash dourado no card inteiro quando rola gol (contido, paint-only) */
.live-card.goal-flash {
  position: relative;
  overflow: hidden;
}
.live-card.goal-flash::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(
    ellipse at center,
    rgba(245,185,66,0.22) 0%,
    rgba(245,185,66,0.10) 40%,
    transparent 75%
  );
  animation: goal-flash-bg 1.6s ease-out;
  pointer-events: none;
  z-index: 1;
}
.live-card.goal-flash > * { position: relative; z-index: 2; }
@keyframes goal-flash-bg {
  0%   { opacity: 0;    transform: scale(0.9); }
  20%  { opacity: 1;    transform: scale(1.05); }
  60%  { opacity: 0.5;  transform: scale(1);    }
  100% { opacity: 0;    transform: scale(1);    }
}

/* slot: ancora a bola + explosao ao redor do numero */
.goal-num-slot {
  position: relative;
  display: inline-block;
}

/* bola voa ate o placar e explode */
.goal-strike {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 26px; height: 26px;
  margin-top: -13px; margin-left: -13px;
  font-size: 26px;
  line-height: 26px;
  text-align: center;
  filter:
    drop-shadow(0 0 8px rgba(245,185,66,1))
    drop-shadow(0 0 16px rgba(245,185,66,0.55))
    drop-shadow(0 2px 4px rgba(0,0,0,0.40));
  pointer-events: none;
  z-index: 5;
  animation: goal-strike-fly 0.4s cubic-bezier(.55,0,.85,.4) both;
  will-change: transform, opacity;
}
@keyframes goal-strike-fly {
  0%   { transform: translateX(-60px) scale(0.45); opacity: 0; }
  25%  { transform: translateX(-44px) scale(0.75); opacity: 1; }
  75%  { transform: translateX(-10px) scale(1.45); opacity: 1; }
  100% { transform: translateX(0)     scale(1.7);  opacity: 0; }
}

/* explosao centrada no placar */
.goal-blast {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 14px; height: 14px;
  margin-top: -7px; margin-left: -7px;
  border-radius: 50%;
  pointer-events: none;
  z-index: 4;
  background: radial-gradient(circle, rgba(255,240,180,1) 0%, rgba(245,185,66,0.85) 35%, rgba(245,185,66,0) 70%);
  animation: goal-blast-core 0.7s cubic-bezier(.16,.86,.4,1) 0.38s both;
  box-shadow: 0 0 0 0 rgba(245,185,66,0.95);
}
.goal-blast::before, .goal-blast::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 3px solid var(--brand-gold, #f5b942);
  animation: goal-blast-ring 0.85s cubic-bezier(.2,.7,.3,1) 0.38s both;
}
.goal-blast::after {
  border-color: rgba(245,185,66,0.55);
  border-width: 2px;
  animation-delay: 0.48s;
  animation-duration: 0.75s;
}
@keyframes goal-blast-core {
  0%   { transform: scale(0.2);  opacity: 0;   box-shadow: 0 0 0 0 rgba(245,185,66,0); }
  18%  { transform: scale(2.4);  opacity: 1;   box-shadow: 0 0 30px 6px rgba(245,185,66,0.85); }
  55%  { transform: scale(1.4);  opacity: 0.6; box-shadow: 0 0 40px 10px rgba(245,185,66,0.30); }
  100% { transform: scale(0.6);  opacity: 0;   box-shadow: 0 0 0 0 rgba(245,185,66,0); }
}
@keyframes goal-blast-ring {
  0%   { transform: scale(0.4); opacity: 0; border-width: 4px; }
  10%  { transform: scale(1.2); opacity: 1; border-width: 3px; }
  60%  { transform: scale(4.5); opacity: 0.4; border-width: 1.5px; }
  100% { transform: scale(7);   opacity: 0; border-width: 0; }
}
@media (prefers-reduced-motion: reduce) {
  .goal-num-pop, .live-card.goal-flash::before, .goal-strike,
  .goal-blast, .goal-blast::before, .goal-blast::after { animation: none !important; }
  .goal-num-pop { color: var(--brand-gold, #f5b942); text-shadow: 0 0 4px rgba(245,185,66,0.6); }
}

/* #8 + #9 jogos toolbar (filtro casa + busca) */
.jogos-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 0 16px;
  flex-wrap: wrap;
}
.house-pills { display: flex; gap: 6px; }
.house-pill {
  padding: 7px 14px;
  border-radius: 999px;
  border: 1px solid var(--line-2, rgba(255,255,255,0.1));
  background: rgba(255,255,255,0.03);
  color: var(--text-2, #9aa6b2);
  font: 600 12px/1 var(--f-ui, 'Inter Tight');
  cursor: pointer;
  transition: all 0.15s ease;
}
.house-pill:hover { background: rgba(255,255,255,0.07); color: var(--text-1); }
.house-pill.active { background: var(--accent, #f5b942); color: #1a0f00; border-color: var(--accent); font-weight: 700; }
.house-pill.active.stake { background: #3b82f6; color: #fff; border-color: #3b82f6; }
.house-pill.active.esportiva { background: #f15a2b; color: #fff; border-color: #f15a2b; }
.jogos-search {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 10px;
  border: 1px solid var(--line-2, rgba(255,255,255,0.1));
  background: rgba(255,255,255,0.03);
  color: var(--text-3, #6a7585);
  flex: 1;
  max-width: 280px;
}
.jogos-search input {
  flex: 1;
  background: transparent;
  border: 0;
  outline: 0;
  color: var(--text-0, #e8eef5);
  font: 500 13px/1 var(--f-ui, 'Inter Tight');
}
.jogos-search .js-clear {
  background: transparent; border: 0; color: var(--text-3);
  font-size: 18px; cursor: pointer; line-height: 1; padding: 0 2px;
}
@media (max-width: 720px) {
  .jogos-toolbar { flex-direction: column; align-items: stretch; }
  .jogos-search { max-width: none; }
  .house-pills { justify-content: space-between; }
  .house-pill { flex: 1; text-align: center; }
}

/* #3 Skeletons shimmer */
.skl {
  position: relative;
  overflow: hidden;
  background: rgba(255,255,255,0.04);
  border-radius: 8px;
}
.skl::after {
  content: '';
  position: absolute; inset: 0;
  transform: translateX(-100%);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.07), transparent);
  animation: skl-shimmer 1.3s infinite;
}
@keyframes skl-shimmer { 100% { transform: translateX(100%); } }
.skl-kpi { height: 92px; }
.skl-card { height: 200px; margin-bottom: 14px; }
.skl-bubble { width: 62px; height: 62px; border-radius: 50%; }

/* #7 Photo fallback estilizado (top ELO + streaks) */
.rank-row .ph, .streak-row .ph {
  background: linear-gradient(135deg, rgba(245,185,66,0.18), rgba(245,185,66,0.04));
  color: var(--accent, #f5b942);
  font: 700 12px/1 var(--f-ui, 'Inter Tight');
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.rank-row .ph img, .streak-row .ph img {
  width: 100%; height: 100%; object-fit: cover; border-radius: inherit;
}

/* #19 Pull-to-refresh indicator */
.ptr-indicator {
  position: fixed;
  top: 0; left: 50%;
  transform: translateX(-50%) translateY(-100%);
  z-index: 200;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--bg-1, #0c1729);
  border: 1px solid var(--line-2);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 12px rgba(0,0,0,0.4);
  transition: transform 0.2s ease, opacity 0.2s ease;
  opacity: 0;
  pointer-events: none;
}
.ptr-indicator.visible { opacity: 1; }
.ptr-indicator svg { width: 18px; height: 18px; color: var(--accent); }
.ptr-indicator.spinning svg { animation: ptr-spin 0.8s linear infinite; }
@keyframes ptr-spin { to { transform: rotate(360deg); } }

/* #13 Badge pulse quando count muda (key remonta o span → anima entrada) */
.nav-item .count {
  animation: badge-bump 0.5s cubic-bezier(.16,.86,.4,1);
}
@keyframes badge-bump {
  0% { transform: scale(1); }
  35% { transform: scale(1.35); background: var(--accent, #f5b942); color: #1a0f00; }
  100% { transform: scale(1); }
}
/* No bottom-nav mobile o count fica posicionado absoluto — preserva e anima */
@media (max-width: 900px) {
  .nav-item .count { animation: badge-bump-mobile 0.5s cubic-bezier(.16,.86,.4,1); }
  @keyframes badge-bump-mobile {
    0% { transform: scale(1); }
    35% { transform: scale(1.4); }
    100% { transform: scale(1); }
  }
}


/* ===== H2H modal close (mais visível) ===== */
.h2h-modal .modal-close,
.h2h-detail-overlay .modal-close {
  width: 34px; height: 34px;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0;
  font-size: 24px; font-weight: 700; line-height: 1;
  color: var(--text-0);
  background: var(--bg-2, rgba(255,255,255,0.06));
  border: 1.5px solid var(--line-2, rgba(255,255,255,0.18));
  border-radius: 50%;
  box-shadow: 0 2px 8px rgba(0,0,0,0.35);
  transition: all .14s ease;
}
.h2h-modal .modal-close:hover,
.h2h-detail-overlay .modal-close:hover {
  color: #fff;
  background: var(--loss, #f15a5a);
  border-color: var(--loss, #f15a5a);
  transform: scale(1.06);
  box-shadow: 0 0 0 4px rgba(241,90,90,0.18), 0 2px 10px rgba(0,0,0,0.4);
}

/* ===== Loading da tabela de Análise (feedback ao trocar filtro) ===== */
.stats-loading-pill{
  display:inline-flex; align-items:center; gap:6px; margin-left:10px;
  padding:2px 9px; border-radius:999px; vertical-align:middle;
  background:rgba(54,211,153,0.12); border:1px solid rgba(54,211,153,0.35);
  color:var(--win,#36d399); font:600 10px/1 var(--f-ui); letter-spacing:0.02em;
  text-transform:none;
}
.stats-spin{
  width:10px; height:10px; border-radius:50%;
  border:2px solid rgba(54,211,153,0.35); border-top-color:var(--win,#36d399);
  animation:stats-spin 0.7s linear infinite;
}
@keyframes stats-spin{ to{ transform:rotate(360deg); } }
.stats-table-wrap.is-loading{
  opacity:0.45; pointer-events:none; transition:opacity 0.15s ease;
}


/* ===== Balões de comunidade (WhatsApp / Telegram) no carrossel ===== */
.promo-bubble.community-bubble{
  display:flex; align-items:center; justify-content:center;
  border:none; padding:0;
}
.promo-bubble.community-bubble.wa{
  background:radial-gradient(circle at 30% 22%, #5ffc7b 0%, #25D366 55%, #128C7E 100%);
  box-shadow:0 2px 10px rgba(37,211,102,0.35), inset 0 -3px 8px rgba(0,0,0,0.25);
}
.promo-bubble.community-bubble.tg{
  background:radial-gradient(circle at 30% 22%, #4cc4f5 0%, #229ED9 55%, #1c7cb0 100%);
  box-shadow:0 2px 10px rgba(34,158,217,0.35), inset 0 -3px 8px rgba(0,0,0,0.25);
}
.promo-bubble.community-bubble svg{ filter:drop-shadow(0 1px 2px rgba(0,0,0,0.25)); }

/* ===== Empty-state: sem jogos ao vivo (G1 audit) ===== */
.live-empty{
  display:flex; align-items:center; gap:12px;
  padding:18px 16px; color:var(--text-3);
}
.live-empty svg{ color:var(--text-3); opacity:0.7; flex:0 0 auto; }
.live-empty-txt{ display:flex; flex-direction:column; gap:2px; }
.live-empty-txt b{ color:var(--text-1); font:600 13px/1.3 var(--f-ui); }
.live-empty-txt span{ font:400 12px/1.35 var(--f-ui); color:var(--text-3); }


/* ===== jogos-compact-legado — /jogos mobile mais denso (estilo legado) ===== */
@media (max-width: 720px) {
  .match-row { padding: 8px 11px !important; gap: 6px; margin-bottom: 8px; border-radius: 10px; }
  .match-row .match-info .top { margin-bottom: 3px; gap: 6px; }
  .match-row .match-info .top .tempo { font-size: 10px; }
  .match-row .match-info .top .min,
  .match-row .match-info .top .period { font-size: 9px; }
  .match-row .team { padding: 2px 0; }
  .match-row .team span:first-child { font-size: 12px; }
  .match-row .team .pl { font-size: 9.5px; }
  .match-row .team .score { font: 800 14px/1 var(--f-mono); min-width: 20px; }
  .match-row .right-stack { padding-top: 3px !important; gap: 7px; }
  .match-row .analisar-btn { padding: 6px 10px; font-size: 11px; }
  .match-row .casa-hint { padding: 4px 9px; font-size: 10px; }
}

/* BetMGM (casa do cyber) — round-6 dash */
.sq-cta.betmgm{background:linear-gradient(135deg,#1a7a4f,#0d5236);color:#fff;border:1px solid #2ea36b;}
.sq-cta.betmgm:hover{filter:brightness(1.12);}
.casa-hint.betmgm{color:#2ea36b;}
.house-pill.betmgm.active{background:#1a7a4f;border-color:#2ea36b;color:#fff;}
